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(57) Abstract: The present invention is directed to a method, 
system and program for exporting-importing the content of in- 
put cells from a source scalable template instance in a source 
multi-dimensional spreadsheet to a destination scalable template 
instance in a destination multi-dimensional spreadsheet; a multi- 
dimensional spreadsheet comprising a plurality of cells identi- 
fied by a cell address along each dimension; a scalable template 
instance comprising a variable number of contiguous elements 
of same size ordered and aligned along a given spreadsheet di- 
mension and structured according to information defined in an 
associated scalable template; an element being defined as a range 
of cells; a range of cells comprising one or a plurality of cells; 
said scalable template comprising an element profile; an element 
profile defining a cell content and a cell destination for each cell 
within each element; said cell destination specifying whether the 
cell is an input ceU for receiving an entry or an output cell for 
producing a result. The method comprises the steps of: detect- 
ing a conunand for exporting-importing input cells firom a source 
scalable template instance in a source spreadsheet to a destina- 
tion scalable template instance in a destination spreadsheet; iden- 
tifying the source scalable template associated with the source 
scalable template instance; identifying cells, if there are any, de- 
fined as input cells in the element profile of the source scalable 
template; identifying the destination scalable template associated 
with the destination scalable template instance; Identifying cells, 
if there are any, defined as input cells in the element profile of 
the destination scalable template; copying cell per cell, the content of each input cell of the source scalable 36 template instance in 
each input cell of the destination scalable template instance. 
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SYSTEM AND METHOD IN A SPREADSHEET FOR 
EXPORTING-IMPORTING THE CONTENT OF INPUT CELLS FROM A 
SCALABLE TEMPLATE INSTANCE TO ANOTHER 

Technical field of the invention 

5 The present invention relates to the field of Infomiation processing by digital 
computers, more particularly to a method and system for exporting-importing the 
content of input cells from a source scalable template instance in a source 
multi-dimensional spreadsheet to a destination scalable template instance in a 
destination multi-dimensional spreadsheet; a multi-dimensional spreadsheet 

10 comprising a plurality of cells identified by a cell address along each dimension, a 
scalable template instance comprising a variable number of contiguous elements of 
same size ordered and aligned along a given spreadsheet dimension and structured 
according to infomnation defined in an associated scalable template. 

BaciQground art 

IS Before computers, numerical analyses, particularly financial ones, were usually 
prepared on an accountant's columnar pad or spreadsheet, with pencil and 
calculator in hand. By organizing data into columns and rows, spreadsheets afford 
the rapid assimilation of infomiation by a reader. The task of preparing a 
spreadsheet on paper, however, is not quite so fast. Instead, the process tends to 

20 be very slow, as each entry must be tediously calculated and entered into the 
spreadsheet. Since all calculations are the responsibility of the preparer, manually 
prepared spreadsheets are also prone to enters. Hence, preparation of spreadsheets 
by hand is slow, tedious, and unreliable. 

With the advent of microcomputers, a solution was forthcoming in the fomi of 
25 "electronic spreadsheets." Better known simply as "spreadsheets," these software 
programs provide a computerized replacement for the traditional financial modelling 
tools: the accountant's columnar pad, pencil, and calculator. In some regards, 
spreadsheet programs are to those tools what word processors are to typewriters. 
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Spreadsheets offer dramatic Improvements in ease of creating, editing, and using 
financial models. 

A typical spreadsheet program configures the rfiemory of a computer to resemble 
the column/row or grid fomnat of an accountant's columnar pad, thus providing a 

5 visible calculator for a user. Because this "pad" exists dynamically in the computer's 
memory, however, it differs from paper pads in several important ways. Locations in 
the electronic spreadsheet, for example, must be communicated to the computer in 
a format which it can understand. A common scheme for accomplishing this is to 
assign a number to each row in a spreadsheet, and a letter to each column. To 

10 reference a location at column A and row 1 (i.e., the upper-left hand comer), for 
example, the user types in "Ar. In this manner, the spreadsheet defines an 
addressable storage location or "cell" at each intersection of a row with a column. 

Data entry into an electronic spreadsheet occurs in much the same manner that 
infonmation would be entered on an accountant's pad. After a screen cursor is 

15 positioned at a desired location, the user can enter alphanumeric information. 
Besides holding text and numeric information, however, spreadsheet cells can store 
special instructions or "fomnulas" specifying calculations to be perfomried on the 
numbers stored in spreadsheet cells. In this fashion, cell references can serve as 
variables in an equation, thereby allowing precise mathematical relationships to be 

20 defined between cells. The structure and operation of a spreadsheet program, 
including advanced functions such as functions and macros, are documented in the 
technical, trade, arid patent literature. For an overview, see e.g., Cobb, S., Using 
Quattro Pro 2, Borland-OsbomelMcGraw-IVIII, 1990; and LeBlond, G. and Cobb, D., 
Using 1-2-3, Que corp., 1985. The disclosures of each of the foregoing are hereby 

25 incorporated by reference. 

Electronic spreadsheets offer many advantages over their paper counterparts. For 
one, electronic spreadsheets are much larger (i.e., hold more infomnation) than their 
paper counterparts; electronic spreadsheets having thousands or even millions of 
cells are not uncommon. Spreadsheet programs also allow users to perfomri 
30 "what-if scenarios. After a set of computational relationships has been entered into 
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a worksheet, thanks to imbedded formulas and/or built-in functions for instance, the 
spread of infonnation can be recalculated using different sets of assumptions, with 
the results of each recalculation appearing almost instantaneously. Perfonning this 
operation manually, with paper and pencil, would require recalculating every 
5 relationship In the model with each change made. Thus, electronic spreadsheet 
systems were invented to solve "what-if problems, that is. changing an input and 
seeing what happens to an output. 

As exposed above, one essential value of an electronic spreadsheet is to organize 
data into columns and rows, while automating tedious calculations. A typical, 

10 common, and valuable example of such a set of data organized into columns and 
rows is a range of cells. Even if a range of cells receives a formal and strict definition 
within electronic spreadsheet environments, it is flexible enough so that infomiation 
can be included in either a single range of cells or in a set of several ranges of cells. 
Ranges of cells therefore are quite useful objects. A range of cell can be defined 

15 and processed as a whole entity. For example it can be copied from one place to 
another place within the spreadsheet or from one spreadsheet file to another 
spreadsheet file. 

Ranges of cells are widely used in applications developed in the field of electronic 
spreadsheets. Most often, the ranges of cells are arranged according to some kind 

20 of structure, thus becoming structured ranges of cells. The contents of each cell is 
defined within an element, where an element is defined as a row of a structured 
range of cells, and then the same kind of element is repeated a certain number of 
times, to store/process a variable number of infomiation pieces. Most of the time, 
several instances of similar stmctured ranges of cells .are used. In the current 

25 context where no other tool is really available, instances of such similar stnjctured 
ranges of cells are frequently created through cut/copy and paste operations. 

Creating a new instance of a structured range of cells is complex and lengthy, 

particularly because a conventional range of cells shows strong limitations : 
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• (i) Structure information (such as number of columns, number of rows), fomiat 
Infonmation (such as font style, color or border), and contents Information (such 
as fomnulas or raw - or informative - data) are mixed, 

• (il) the size of the range of cell is fixed at a given instant. 

5 Therefore, when a spreadsheet user wants to create another range of cells with an 
identical structure, he/she needs to perfonn successively several operations. He/she 
needs to : 

1 . copy-paste an existing structured range of cells, 

2. distinguish between areas containing raw - or infomiative - data and areas 
10 containing generic content such as fomnulas, 

3. empty the copied structured range of cells of the copied raw data while trying to 
keep the structure, fomnat and generic contents, 

4. adjust the size of the structured copied range of cells to his new needs. 

5. eventually, fill the raw data area with default values, in order to ease subsequent 
15 data entry. 

Furthermore, before copying and pasting a structured range of cells, the user must 
prepare the place for the copied structured range of cells, with the risk of ovenwriting, 
and therefore loosing the preexisting infomnation at the destination location. This 
chain of operations rapidly becomes tedious, lengthy and prone to error, especially 
20 when manipulated structured ranges of cells increase in size and complexity. 

Updating a structured range of cells is also very often compiex, iengthy and 
prone to error. Such updates include additions of new elements and modifications 
of existing elements. Several types of modifications can be perfomned without any 
specific problem in an electronic spreadsheet environment. However, this is not the 
25 case for some modifications, for instance for insertions. 

For example, if a row is added by means of a conventional function such as the 
spreadsheet row insertion method, the created row will be empty. This means that 
the value for every cell of every element needs to be entered. Entering data or 
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executing copy/paste operations represents an important workload for the user, 
while the content of each element is known to a certain extent, and should follow the 
general structure of the structured range of cells. Moreover, nonmal spreadsheet 
functions such as the row insertion function may jeopardize the contents of some 

5 neighbour elements. A good exemple of an insertion jeopardising neighbour 
elements Is the insertion of a row in a range of cells in which, on every row, a cell 
such as C17 or more generally (Cn), is pointing to a cell in the previous row, through 
a formula such as C16+B17. or more generally (Cn-1)+(Bn). After row insertion 
between rows 16 and 17, the formula in cell CIS becomes C16+B18 instead of the 

10 generic fomnula C17+B18, or more generally after row insertion between rows (n-1) 
and (n). the formula in cell (Cn+1) becomes (Cn-1)+(Bn+1) instead of the generic 
fomnula (Cn)+{Bn+1). 

As a second exemple, there are cases where modifications must be done 
consistently throughout the staictured range of cells. Today, this can only be done 
15 using specific copy-paste operations applied to the exact area to be modified. This 
may prove to be very difficult, especially when manipulated structured ranges of 
cells increase in size and complexity. 

Deleting an element of a structured range of cells is an operation prone to 
error. As a matter of fact, nornial spreadsheet functions such as the row deletion 

20 function may jeopardize the contents of some neighbour elements, leading to 
unresolved references (#REF results) or, even worse to wrong formulas that may be 
difficult to identify. Solving this problem requires additional "context intelligence", 
taking into account the structure of the structured range of cells in which the element 
deletion occurs. Another need appears at the time the user invokes the conventional 

25 Delete function after selection in the spreadsheet of one or a plurality of cells. If the 
selection belongs to a structured range of cells, calling the Delete function by means 
of a menu or by pressing the "Delete" key. leaves room to ambiguity as to what the 
user wants to perfomi. Removing this ambiguity can only be done today by selecting 
the exact area to be deleted, which may prove to be very difficult, especially as 

30 manipulated structured ranges of cells increase in size and complexity. Solving this 
problem requires additional "context Intelligence" to detect this situation, take 
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advantage of the stmcture of the staictured range of cells and offer the relevant 
choice to the user. 

The amount of storage that is necessary to save a structured range of cells 
may become prohibitive when such a structured range of cells grows in size. On 

5 another hand, an important portion of each element of such a structured range of 
cells mdy be constituted of OUT fields containing fomiulas, without any user 
provided data. Those fields are similar from element to element, and comprise 
redundant information. This infomnation is not redundant from an end user 
standpoint, since it is certainly useful, but is redundant because it can be recreated 

10 from the base structure of the structured range of cells. Storing and/or conveying 
this redundant information is a waste that could be avoided if a mechanism would 
allow to only store/convey the informative data and the infonmation related to the 
base structure of the structured range of cells. 

Sorting data within a selected range of cells introduces the risk of 
15 jeopardising any neighbouring structured range of cells. This risk exists 
because the selected range of cells is sorted, regardless of the existence of any 
neighbouring structured range of cells and regardless of the respective positions of 
the selected range of cells versus any neighbouring structured range of cells. The 
risk can be avoided only by a careful and precise selection of the range to sort. This 
20 selection is prone to error, especially when stmctured ranges of cells grow in size 
and complexity. Improved control over sort operations are possible by taking into 
account the structure and the position of the structured ranges of ceils. 

The United States Patent 5,033,009 is an interesting piece of prior art, that develops 
the concepts of pattem data and variable data that may be integrated to generate a 
25 worksheet file through a worksheet file generator. 

This invention however shows many limitations preventing it from solving the set of 
issues presented here above and, in particular : 

• it aims at producing a new output spreadsheet from a set of two input files, while 
there is a need, within a user application environment, to create and manipulate 
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new entities within an existing electronic spreadsheet file, that the user is familiar 
with. 

• It contains no mechanism allowing the direct update of the output spreadsheet, 
other than the regular spreadsheet tool. 

5 • It contains no capability to ^manipulate within the same spreadsheet file, a 
variable number of different structures and a variable number of instances of 
each of those structure. The granularity is limited to the spreadsheet file, while 
the required granularity is that of a structured range of cells. 

• The so called "file format specification" really mixes structure infonnation (such 
10 as number and relative position of columns and rows), presentation infonmation 

(such as font, color, background, etc.), contents infomiatlon (such as fonmulas, 
etc.). 

Summary of the invention 

As defined in independent claims, the present invention is directed to a method, 
15 system and program for exporting-importing the content of input cells from a source 
scalable template instance in a source multi-dimensional spreadsheet to a 
destination scalable template instance in a destination multi-dimensional 
spreadsheet; a multi-dimensional spreadsheet comprising a plurality of cells 
identified by a cell address along each dimension; a scalable template instance 
20 comprising a variable number of contiguous elements of same size ordered and 
aligned along a given spreadsheet dimension and staictured according to 
information defined in an associated scalable template; an element being defined as 
a range of cells; a range of cells comprising one or a plurality of cells; said scalable 
template comprising an element profile; an element profile defining a cell content 
25 and a cell destination for each cell within each element; said cell destination 
specifying whether the cell is an input cell for receiving an entry or an output cell for 
producing a result. 

The method comprises the steps of: 
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• Detecting a command for exportlng-importing input cells from a source scalable 
template instance in a source spreadsheet to a destination scalable template 
instance in a destination spreadsheet; 

• Identifying the source scalable template associated with the source scalable 
S template instance; 

• Identifying cells, if there are any, defined as input cells in the element profile of 
the source scalable template; 

• Identifying the destination scalable template associated with the destination 
scalable template instance; 

10 • Identifying cells, if there are any, defined as input cells in the element profile of 
the destination scalable template; 

• Copying cell per cell, the content of each input cell of the source scalable 
template instance in each input cell of the destination scalable template instance. 

Further embodiments of the invention are provided in the appended dependent 
IS claims. 

The foregoing, together with other objects, features, and advantages of this 
invention can be better appreciated with reference to the following specification, 
claims and drawings. 

Brief description of the drawings 

20 The novel and inventive features believed characteristics of the Invention are set 
forth in the appended claims. The invention itself, however, as well as a prefenred 
mode of use, further objects and advantages thereof, will best be understood by 
reference to the following detailed description of an illustrative detailed embodiment 
when read in conjunction with the accompanying drawings, wherein : 

25 • Figure 1A is a schematic view of a computer system in which the present 
invention may be embodied. 
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• Figure IB is a schematic view of a software system including an operating 
system, an application software, and a user interface for canying out the present 
invention. 

• Figure 1C illustrates the basic architecture and functionality of a graphical user 
S interface in which the present Invention may be embodied. 

• Figure 2A shows a spreadsheet notebook interface according to the preferred 
embodiment of the present Invention. 

• Figure 2B shows the toolbar component of the notebook interface shown in 
Figure 2A. 

10 • Figures 2C and 2D show page identifiers for rapidly accessing and manipulating 
individual pages of the notebook interface shown in Figure 2A. 

• Figure 3 illustrates the concepts of formats, profiles, and scalable templates, 
according to the preferred embodiment of the present invention. 

• Figures 4A and 48 illustrate the concepts of scalable template instances, 
IS according to the preferred embodiment of the present Invention. 

• Figure 5 provides a structured organisational view of the concepts of formats, 
profiles, scalable templates, and scalable template instances according to the 
preferred embodiment of the present invention. 

• Figures 6A, 6B, 6C and 6D show a preferred spreadsheet user interface, 
20 according to the preferred embodiment of the present invention, respectively for 

managing scalable templates, for editing formats, for editing profiles and for 
editing scalable templates. 

• Figures 7A, 7B, 7C, 7D, 7E, 7F, 7G and 7H respectively illustrate the structure of 
the Element Fomriat Table (EFT), of the Element Profile Table (EPT), of the 
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Scalable Template Table (STT), of the Scalable Template Manager Table 
(STMT), of a Scalable Template Descriptor Table (STDT), of the Scalable 
Template Instance Table (STIT), of a Scalable Template Export-Import Table 
(STEIT), and of the Scalable Template Instance Export-Import Table (STIEIT) 
according to the prefen'ed embodiment of the present Invention. 

Figure 71 gives a graphical illustration of the relationships established between 
the tables EFT. EPT, STT, STDT, and STIT according to the preferred 
embodiment of the present invention. 

Figure 8 is a flow chart illustrating a prefenred method for managing scalable 
template objects according to a prefered embodiment of the present invention. 

Figure 9 is a flow chart illustrating a preferred method for editing element fomnats 
and meta-element fomiats according to a prefenred embodiment of the present 
invention. 

Figure 10 is a flow chart illustrating a preferred method for editing element 
profiles and meta-element profiles according to a preferred embodiment of the 
present invention. 

Figures 11A, 11B, 11C, 110, 11E, 11F, 11G, 11H. Ill and 11J illustrate the 
limitations of conventional means available in conventional electronic 
spreadsheet environments for managing structured ranges of cells. 

Figures 12 is a flow chart illustrating a preferred method for editing a scalable 
template according to a preferred embodiment of the present invention. 

Figure 13A shows a preferred spreadsheet user interface, according to the 
preferred embodiment of the present invention, for creating scalable template 
instances. 
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Figures 13B, 13C, 13D, 13E, 13F and 13G illustrate the different modes of 
scalable template instanciatlon, according to a prefen-ed embodiment of the 
present invention. 

Figure 14 is a flow chart Illustrating a prefen^ed method for creating scalable 
template instances according to a preferred embodiment of the present 
invention. 

Figure 15 is a flow chart illustrating a preferred method for managing insertion in 
scalable template instances according to a prefenred embodiment of the present 
Invention. 

Figures 16A, and 16B show each a preferred spreadsheet user interface, 
according to the prefen-ed embodiment of the present invention, for managing 
insertion in scalable template instances. 

Figures 17A, 17B, 17C, 17D, 17E, 17F, 17G and 17H illustrate the different 
modes of scalable template instance insertion, according to a preferred 
embodiment of the present invention. 

Figure 18 is a flow chart illustrating a preferred method for managing deletion in 
scalable template instances according to a preferred embodiment of the present 
invention. 

Figures 19A, and 198 show each a preferred spreadsheet user interface, 
according to the preferred embodiment of the present invention, for managing 
deletion in scalable template instances. 

Figures 20A, 20B, 20C, 20D, and 20E illustrate the different modes of scalable 
template instance deletion, according to a prefen-ed embodiment of the present 
invention. 
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Figure 21 is a flow chart illustrating a preferred method for refreshing scalable 
template instances according to a prefen-ed embodiment of the present 
invention. 

Figures 22A, and 22B show each a prefenred spreadsheet user interface, 
according to the prefenred embodiment of the present invention, for refreshing 
scalable template instances. 

Figure 23A shows a prefenred spreadsheet user interface, according to the 
preferred embodiment of the present invention, for copying scalable template 
instances. 

Figure 23B shows a prefenred spreadsheet user interface, according to the 
preferred embodiment of the present invention, for cutting scalable template 
instances. 

Figure 23C shows a preferred spreadsheet user interface, according to the 
preferred embodiment of the present invention, for pasting scalable template 
instances. 

Figure 24A is a flow chart illustrating a preferred method for copying scalable 
template instances according to a preferred embodiment of the present 
invention. 

Figure 24B is a flow chart illustrating a preferred method for cutting scalable 
template instances according to a preferred embodiment of the present 
invention. 

Figure 24C is a flow chart illustrating a preferred method for pasting scalable 
template instances according to a preferred embodiment of the present 
invention. 
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• Figure 25A is a flow chart illustrating a preferred method for exporting scalable 
template Items (element fomiats, or meta-element fomiats. or element profiles, 
or meta-element profiles, or scalable templates) according to a preferred 
embodiment of the present invention. 

S • Figure 25B is a flow chart illustrating a preferred method for importing scalable 
template items (element formats, or meta-element fomiats, or element profiles, 
or meta-element profiles, or scalable templates) according to a preferred 
embodiment of the present invention. 

• Figure 26A shows a prefenred spreadsheet user interface, according to the 
10 prefen-ed embodiment of the present invention, for exporting scalable template 

items (element fonmats, or meta-element fomiats, or element profiles, or 
meta-element profiles, or scalable templates). 

• Figure 26B shows a preferred spreadsheet user interface, according to the 
preferred embodiment of the present invention, for importing scalable template 

15 items (element fomiats, or meta-element fomnats, or element profiles, or 
meta-element profiles, or scalable templates). 

• Figures 26C illustrates the logical file structure of the export-import files, 
according to the preferred embodiment of the present invention. 

• Figure 27A shows a [Drefenred spreadsheet user interface, according to the 
20 prefenred embodiment of the present invention, for exporting scalable template 

instances. 

• Figure 27B shows a preferred spreadsheet user interface, according to the 
preferred embodiment of the present invention, for importing scalable template 
instances. 

25 • Figure 27C illustrates the.staicture of the Exported Scalable Template Instance 
Table (ESTIT) according to a preferred embodiment of the present Invention. 
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• Figure 28A is a flow chart illustrating a preferred method for exporting scalable 
template instances according to a preferred embodiment of the present 
invention. 

• Figure 28B is a flow chart illustrating a prefen-ed method for importing scalable 
5 template instances according to a prefenred embodiment of the present 

invention. 

• Figure 29A is a flow chart illustrating a preferred method for sorting scalable 
template instances according to a preferred embodiment of the present 
invention. 

10 • Figure 29B shows a preferred spreadsheet user interface, according to the 
preferred embodiment of the present invention, for sorting scalable template 
instances. 

Detailed description of ttie preferred embodiment 

SYSTEM HARDWARE 

15 As shown in FIG. 1A, the present invention may be embodied on a computer system 
100 comprising a central processor 101, a main memory 102, an input/output 
controller 103, a keyboard 104, a pointing device 105 (e.g., mouse, track ball, pen 
device, or the like), a display device 106, and a mass storage 107 (e.g., hard disk). 
Additional input/output devices, such as a printing device 108, may be included in 

20 the system 100 as desired. As illustrated, the various components of the system 100 
communicate through a system bus 110 or similar architecture. In a preferred 
embodiment, the computer system 100 includes an IBM-compatible personal 
computer, which is available from several vendors (including Intemational Business 
Machine - IBM Corporation of Amionk, N.Y.). 

14 



wo 03/014987 



PCT/EP02/09483 



Illustrated in FIG. 1B. a computer software system 150 is provided for directing the 
operation of the connputer system 100. Software system 150, which is stored in 
system memory 102 and on disk memory 107, includes a kemel or operating system 
151 and a shell or interface 153. One or more application programs, such as 

5 application software 152, may be "loaded* (i.e., transfen-ed from storage 107 into 
memory 102) for execution by the system 100. The system 100 receives user 
commands and data through user interface 153; these inputs may then be acted 
upon by the system 100 in accordance with instructions from operating module 151 
and/or application module 152. The interface 153, which is preferably a graphical 

10 user interface (GUI), also serves to display results, whereupon the user may supply 
additional inputs or terminate the session. In a preferred embodiment, operating 
system 151 and interface 153 are Microsoft Win95, available from Microsoft 
Corporation of Redmond, Wash. Application module 152, on the other hand, 
includes a spreadsheet notebook of the present invention as described in further 

15 detail herein below. 

INTERFACE 
A. Introduction 

The following description will focus on the presently preferred embodiments of the . 
present invention, which are embodied in spreadsheet applications operative in the 

20 Microsoft Win95 environment. The present invention, however, is not limited to any 
particular application or any particular environment. Instead, those skilled in the art 
will find that the system and methods of the present invention may be 
advantageously applied to a variety of system and application software, including 
database management systems, word processors, and the like. Moreover, the 

25 present invention may be embodied on a variety of different platforms, including 
Macintosh, UNIX, NextStep, and the like. Therefore, the description of the 
exemplary embodiments which follows is for purposes of illustration and not 
limitation. 
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Referring now to FIG. 1C, the system 100 includes a windowing interface or 
wori<space 160. Window 160 is a rectangular, graphical user interface (GUI) for 
display on screen 106; additional windowing elements may be displayed in various 
sizes and fomiats (e.g., tiled or cascaded), as desired. At the top of window 160 is a 

5 menu bar 170 with a plurality of user-command choices, each of which may invoke 
additional submenus and software tools for use with application objects. Window 
160 includes a client area 180 for displaying and manipulating screen objects, such 
as graphic object 181 and text object 182. In essence, the client area is a workspace 
or viewport for the user to interact with data objects which reside within the computer 

10 system 100. 

Windowing interface 160 includes a screen cursor or pointer 185 for selecting and 
otherwise invoking screen objects of interest. In response to user movement signals 
from the pointing device 105, the cursor 185 floats (i.e., freely moves) across the 
screen 106 to a desired screen location. During or after cursor movement, the user 
15 may generate user-event signals (e.g., mouse button "clicks'* and "drags") for 
selecting and manipulating objects, as is known in the art. For example. Window 160 
may be closed, re-sized, or scrolled by "clicking" (selecting) screen components 172, 
174/5, and 177/8, respectively. 

In a preferred embodiment, screen cursor 185 is controlled with a mouse device. 
20 Single-button, double-button, or triple-button mouse devices are available from a 
variety of vendors, including Apple Computer of Cupertino, Calif., Microsoft 
Corporation of Redmond, Wash., and Logitech Corporation of Fremont, Calif., 
respectively. More preferably, screen cursor control device 105 is a two-button 
mouse device, including both right and left "mouse buttons." 

25 Programming techniques and operations for mouse devices are well documented in 
the programming and hardware literature; see e.g., Microsoft Mouse Programmer's 
Reference, Microsoft Press, 1989. The general constmction and operation of a GUI 
event-driven system, such as Windows, is also known in the art: see, e.g., Petzold, 
C, Programming Windows, Second Edition, Microsoft Press, 1990. The disclosures 

30 of each are hereby incorporated by reference. 



16 



wo 03/014987 



PCT/EP02/09483 



B. Preferred interface 

Shown in FIG. 2A, a spreadsheet notebook interface of the present invention will 
now be described The spreadsheet notebook or wori<book of the present invention 
Includes a notebook wori<space 200 for receiving, processing, and presenting 

5 information, including alphanumeric as well as graphic infomiation. Notebook 
wort<space 200 includes a menu bar 210, a toolbar 220, a cun-ent cell indicator 230, 
an input line 231, a status line 240, and a notebook window 250. The menu bar 210 
displays and invokes, in response to user inputs, a main level of user commands. 
Menu 210 also invokes additional pull down menus, as is known in windowing 

10 applications. Input line 231 accepts user commands and information for the entry 
and editing of cell contents, which may include data, formulas, macros, and the like. 
Indicator 230 displays an address for the current cursor (i.e., active cell) position, or 
the address or name of a selected named range (i.e. active sfelection). At the status 
line 240, system 100 displays information about the current state of the wort<book; 

15 for example, a "READY" indicator means that the system is ready for the user to 
select another task to be perfomned. 

The toolbar 220, shown in further detail in FIG. 2B, comprises a row or palette of 
tools which provide a quick way for the user to choose commonly-used menu 
commands or properties. In an exemplary embodiment, toolbar 220 Includes file 

20 manipulation buttons 221, printing buttons 222, an undo button 223, cut, copy, and 
paste buttons 224, infomiation pop-up window buttons tool 225, a named range 
selection button 226, a style copy button 227, a column re-sizing button 228, and a 
sum button 229. The functions of these buttons are suggested by their names. For 
instance, buttons 224 cut, copy and paste data and objects to and from Windows' 

25 clipboard. The same actions are also available as corresponding commands in the 
Edit menu (available from menu bar 210). 

The notebook, which provides an interface for entering and displaying information of 
interest, includes a plurality of spreadsheet pages. Each page may include 
conventional windowing features and operations, such as moving, re-sizing, and 
30 deleting. In a preferred embodiment, the notebook includes 256 spreadsheet pages. 
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ail of which are saved as a single disk file on the mass storage 107. Workspace 200 
may display one or more notebooks, each sized and positioned (e.g., tiled, 
overlapping, and the like) according to user-specified constraints. 

Each spreadsheet page of a notebook includes a 2-D spread. Page A from the 
5 notebook 200, for example, includes a grid in row and column fomiat, such as row 3 
and column F. At each row/column intersection, a box or cell (e.g., cell C4) is 
provided for entering, processing, and displaying infonnation in a conventional 
manner. Each cell is addressable, with a selector being provided for indicating a 
currently active one (i.e., the cell that is currently selected). 

10 As shown in FIGS. 2C-D, individual notebook pages are identified by page identifiers 
260, preferably located along one edge of a notebook. In a preferred embodiment, 
each page identifier is in the fomn of a tab member (e.g., members 261a, 262a, 
263a) situated along a top edge of the notebook. Each tab member may include 
representative Indicia, such as textual or graphic labels, including user selected titles 

15 representing the contents of a corresponding page. In FIG. 2C, the tab members 
260 are set to their respective default names. For example, the first three tab 
members (members 261a, 262a, 263a) are respectively set to A, B, and C. Tab 
members are typically given descriptive names provided by the user, however. As 
shown in FIG. 2D, for example, the first three tab members have now been set to 

20 "Contents" (tab member 261b), "Summary" (tab member 262b), and "Jan" (tab 
member 263b). In a similar manner, the remaining tabs are set to subsequent 
months of the year. In this manner, the user associates the page identifiers with 
familiar tabs from an ordinary paper notebook. Thus, the user already knows how to 
select a page or spread of interest: simply select the tab corresponding to the page 

25 (as one would do when selecting a page from a paper notebook). 

In addition to aiding in the selection of an appropriate page of infomiation, the 
user-customizable page identifiers serve aid in the entry of spreadsheet named 
range addresses. For example, when entering a fomnula referring to a named range 
of cells on another page, the user may simply use the descriptive page name in the 
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named range address, thus making it easier for the user to understand the 
relationship of the cell(s) or Infomiation being referenced. 

A general description of the features and operation of the spreadsheet notebook 
interface may be found in Quattro Pro for Windows (Getting Started, User's Guide 
5 and Building Spreadsheet Applications), available from Borland International. 

SCALABLE TEMPLATE MANAGEMENT 

A. Introduction 

The concept of scalable templates 

Conventional electronic spreadsheets include built-in means allowing the 

10 spreadsheet users to easily organize data into columns and rows, while automating 
tedious calculations. This set of organized data can be included in either a single range of 
cells or in a set of several ranges of cells. The range of cells is a quite useful, and widely used 
object in an electronic spreadsheet envirorunent. It can be defined and processed as a whole 
entity. For example it can be copied from one place to another place within the spreadsheet or 

IS from one spreadsheet file to another spreadsheet file. 

Most often, those ranges of cells abides by some kind of structure defining the contents of 
each cell within an element, defined as a row of the range of cells, and then repeating the 
same kind of elements a number of times, to store/process a variable number of information 
pieces. This constitutes a structured range of cells. Referring now to FIG llA, a simple 

20 example of such a structure, called "Cash Accounting Journal'* will be used to illustrate the 
present application. Let us suppose the user is defining a cash accounting journal 1100 for the 
month of April 2001, in which is recorded, for each cash transaction, the date of transaction 
1101, the type of transaction 1102 (say. Sale, Expense, Purchase), the object of the 
transaction 1103, the amount of money "in" 1104, the amount of money "out" 1105, the 

25 resulting balance 1106, and, say, a cumulative sum par type of transaction, i.e., from left to 
right Cumulative Sales 1107, Cumulative Expenses 1108, and Cumulative Purchases 1109. A 
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first data row 1110 contains initial values for the computed fields. A last data row 1111 
contains final values, with the sum of columns "$ In" 1112 and "$ Out" 1113. Two title rows 
1114 and 1115, in Bold, are added for presentation and readability purposes. FIG llA, 
illustrates the structure described above, with 4 (four) transactions already recorded, 1116, 

5 1117, 1118 and 1119. In this example, for each of the 4 (four) transactions, the first 5 (five) 
columns 1101, 1102, 1103, 1104 and 1105 contain raw information to be entered by the user, 
while the last 4 (four) columns 1106, 1107, 1108 and 1109 contain formulas that will provide 
the user with additional information that result fi-om processing the raw data. For example, 
the cell F4 1120 contains the following formula : F3+D4-E4, and provides the new cash 

10 balance, after the transaction. Some of the formulas contained in the structured range of cells 
illustrated in FIG llA, are shown in the table of FIG 111. Now referring again to FIG llA, it 
should be noted, however, that the last 4 (four) columns 1106, 1107, 1108 and 1109, in the 
first data row 1110, contain initial values, i.e. raw data, rather than formulas. For example, 
the cell F3 1121 contains the initial value of the balance at the beginning of the month, i.e. 

15 $100,00. 

Most often also, several instances of similar structured ranges of cells are used. Within the 
logic of our example, as described above and illustrated in FIG llA, a similar structured 
range of cells is created for each month, for exemple, in a new sheet containing an accounting 
journal for a given month. 

20 In the current context of electronic spreadsheet environment, where no other tool is really 
available, instances of such similar structured ranges of cells are frequently be created 
through cut/copy and paste operations. However, a range of cells shows strong limitations : 

• It mixes structure information (such as number of columns, niunber of rows), format 
information (such as font style, color or border), contents information (such as formulas 

25 or raw data). 

• It has a given fixed size at a given instant. 

Therefore, creating a new instance of such a structured range of cells, through copy/paste 
operations, may become complex, lengthy and prone to errors. When the spreadsheet user 
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wants to create another structured range of cells with the same structure, he/she will need to 
successively perform several operations : 

• 1. Copying-pasting an existing structured range of cells, thus obtaining another structured 
range of cells similar to the one illustrated m HG llA. 

5 • 2. Distinguishing between areas containing raw -or informative- data and areas containing 
structure specific information such as formulas, or titles. In our example, that means 
making a distinction between the columns *T)ate" 1101, 'Type of Transaction" 1102, 
"Object of Transaction' 1103, "$ In" 1104, and "$ Out" 1105, which contain raw data, on 
one hand, and the columns "$ Balance" 1106, "Cumulative Sales" 1107, "Cumulative 

10 Expenses" 1108, and "Cumulative Purchases" 1109, which contain formulas, on the other 
hand. But, there are some exceptions to the above distinction : 

• (i) the title rows 1114 and 1115 do not contain raw data or formulas, they contain 
specific titles information, that should be kept unchanged. 

• (ii) the first data row (Initial Balance) 1110 contains title information in cells B3/C3 

15 1122. This title information should be kept unchanged. It also contains initial values . 

rather than formulas in the cells 1121, 1123, 1124, 1125 of the last 4 (four) colunans 
"$ Balance" 1106, "Cumulative Sales" 1107, "Cumulative Expenses" 1108, and 
"Cumulative Purchases" 1109. These initial values must be considered as raw data. 

• (iii) the last data row (Final Results) 1111 contains title information in cells B8/C8 
20 1126, and specific formulas in cells D8 1112 and E8 1113, which should be kept 

unchanged. 

• 3. Emptying the copied structured range of cells of the copied raw data while trying to 
keep the structure, format and generic contents. In our example, and now referring to FIG 
IIB, the following cells should be cleared : A3..A8 1127; B4..E7 1128; F3..B 1129. 
25 Through our example, and, given the distinction described above between contents that 
should be kept unchanged and raw data, we can easily understand the complexity of such 
an action and the number of opportunities for errors, especially as the spreadsheet grows 
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beyond limits that can be easily viewed and controlled. Once this operation is performed, 
the resulting range of cells, appears as illustrated in FIG IIB, 

• 4. Adjusting the size of the copied structured range of cells to his new needs. This size 
adjustment most often relates to the number of elements of the copied structured range of 

S cells, and not to the structure of the copied structured range of cells. In our example, and 
referring to FIG IIB, tiie copied structured range of cells only contains 4 (four) elements 
ready to accept data entry, 1130, 1131, 1132 and 1133. But it is easily conceivable that the 
copied structured range of cells contains several hundred rows, thus making the size 
adjustment a real "must". Back to our exemple, and referring to FIG IIB, we can suppose 

10 the user only needs 3 (three) elements for data entry. He will then decide to suppress 1 
(one) element, for example, the first element 1130 of the new structured range of cells. In 
the current context of electronic spreadsheet environment, where no other tool is really 
available, the user may perform this deletion by using the standard row delete function, or 
by using the standard row delete in selected range only function. With both options, and 

15 depending on the contents of each cell, this may result into errors introduced by the row 
deletion, as illustrated on HG IIC, where cells F4 1134, G4 1135, H4 1136 and 14 1137 
are in error because the formulas they each contain was referring to a cell that disappeared 
during the deletion. The following cells are also shown in error since they reference a cell 
in error. With the first option, another problem may occur if the row also contains other 

20 information outside the range on which the user is performing the delete operation. 

• 5. Correcting any error introduced by the above steps, such as the one described above 
and illustrated in FIG IIC. In our example, and referring to FIG IIC, cell F4 1134, G4 
1135, H4 1136 and 14 1137 have to be corrected by entering the correct formulas. For 
example, in cell F4 1134 the following formula should be entered +F3+D4-E4. The result 

25 of this correction can be seen on FIG IID. 

• 6, Eventually, filling the raw data area with default values, in order to make easier 
subsequent data entry. In our example, and referring to FIG IID, we can imagine that the 
most frequent entry is the sale of a book. Therefore the cells of the colunm 'Type of 
Transaction" 1138 may be initialised with the default value "Sale" and the ceUs of the 
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column "Object of Transaction" 1139 may be initialised with the default value ^'Book", as 
iUustratedonHGllD. 

Furthermore, before the copy-paste operation, on the structured range of cells, takes place, the 
user must prepare the place for the copied structured range of cells, at the destination 
5 location, with the risk, if this is not done, of overwriting, and therefore loosing the preexisting 
information at this location. 

Once the chain of operations described above has been perfonned, the user is 
ready to use the structured range of cells by adding data into ennpty cells and. as 
needed, modifying the existing data (such as the default values predefined in the 
10 columns "Type of Transaction" 1138 and "Object of Transaction" 1139). 

The chain of operations described above rapidly becomes tedious, lengthy and 
prone to error, especially when manipulated structured ranges of cells increase in 
size and complexity. In a preferred embodiment of the present invention, a 
user-friendly solution to these problems is proposed by allowing the electronic 
IS spreadsheet user to: 

• Define a stmcture, for a range of cells, including : 

• (i) an optional header part made of one or more meta-elements ; 

• (ii) a mandatory body part made of one or more elements ; 

• (Hi) an optional footer part made of one or more meta-elements. 

20 The stmcture of each meta-element of the header part may be defined in terms 
of attributes by a meta-element fonnat, and in temis of contents by a 
meta-element profile. 

The stmcture of all elements of the body part, may be defined in terms of 
attributes by an element fomiat, and in temris of contents by an element profile. 
25 The stmcture of each meta-element of the footer part may be defined in tenms of 
attributes by a meta-element format, and in terms of contents by a meta-element 
profile. 

This structure is called a Scalable Template. In summary, the scalable template 
defines a stmcture by specifying the number of fields, by referring to a couple of 



23 



wo 03/014987 



PCT/EP02/09483 



element format and element profile that defines all body elements, and, 
optionally, by referring to one or several couples of meta-element format and 
meta-element profile that define each meta-element of the header part or the 
footer part. 

5 • Manage scalable templates and underneath defined objects, known as element 
fomiats, element profiles, meta-element formats and meta-element profiles. 

• Create, or update element fomiats, meta-element formats. 

• Create, or update element profiles, meta-element profiles. 

• Create, or update a scalable template. 

10 • Create a scalable template instance abiding by a defined scalable template. 

The above set of functions is supported by a set of tools : 

• the ""Scalable Template Managef method, or STM method for short; 

• the ""Element Format Editof method, or EFE method for short; 

• the ''Element Profile Editof method, or EPE method for short; 

15 • the "'Scalable Template Editof method, or STE method for short; 

• the ""Scalable Template Instanciatof method, or STI method for short. 

• This set of functions is defined in much further details, in the following sections. 

In our example, a scalable template is developed to define the generic structure of 
the "Cash Accounting Joumal" and thus to facilitate the creation of several instances 
20 of said "Cash Accounting Joumal". Now referring to FIG 11D, the scalable template 
defining the structure of "Cash Accounting Journal" : 

• (i) Specifies the number of columns or fields, 9 (nine) in our exemple. 

• (ii) Defines the header part of "Cash Accounting Joumal", through the following 
steps : 

25 • Defining the fomiat of the first Title row 1140. through a meta-element fomiat. 
This includes, for example, the Bold type for the font. 

• Defining the contents of the first Title row 1140, through a meta-element 
profile. This includes, for example, the text of the Title. 

• Defining the fomnat of the second Title row 1141, through a meta-element 
30 format. This includes, for example, the Bold type for the font. 

24 
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• Defining the contents of the second Title row 1141, through a meta-element 
profile. This includes, for example, the text of each column title. 

• Defining the fomfiat of the first data row 1142, which contains initial values for the 
computed fields, through a meta-element format This includes, for example, the 

S merge of fields B and C. 

• Defining the contents of the first data row 1142, which contains initial values for 
the computed fields, through a meta-element profile. This includes, for example, 
the text of "Initial Balance". 

• (Hi) Defines the body part of "Cash Accounting Journal", through the following 
10 steps : 

• Defining the fomnat of all standard data rows or elements 1143 to 1145, through an 

element format. 

• Defining the contents of all standard data rows or elements 1143 to 1145, through 
an element profile. This includes, for example, the default value "Sale" in field 

IS 1138, the default value "Book" in field 1139, and the fomnulas in the four 

rightmost fields 1147, 1148, 1149 and 1150. 

• (iv) Defines the footer part of "Cash Accounting Journal", through the following 
steps : 

• Defining the format of the last data row 1146, which contains final values, through 
20 a meta-element format. This includes, for example, the merge of fields B and C. 

• Defining the contents of the last data row 1146, which contains final values, 
through a meta-element profile. This includes, for example, the text of "Final 
Results". 

From the above scalable template, one or several scalable template instances, such 
25 as the one illustrated in FIG 1 1D, can be created, at very limited cost to the user and 
thus avoiding the many risks for error. 

Inserting an element in a scalable template instance 

Given the solution briefly described above, and precisely defined in the following 
sections, the spreadsheet user is now able to define a range of cells structure in a 
30 scalable template, and create a scalable template instance abiding by the structure 
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defined in the scalable template, and comprising a given number of elements, 
initialised thanks to the element format and element profile. In our example of "Cash 
Accounting Journal", the newly created scalable template instance would typically 
appear as illustrated in FIG 11D. Once this creation is completed, the user may now 
S fill in the scalable template instance with data, immediately take advantage of the 
predefined, structured instance that provide the necessary results, and save this 
instance, as part of a spreadsheet file, for further use, as required. In our example, 
and now referring to FIG 11E, the user would enter: 

• (i) the initial values for the field "$ Balance" in cell F3 1151, for the field 
10 "Cumulative Sales" in cell G3 1 152, for the field "Cumulative Expenses" in cell H3 

1153, for the field "Cumulative Purchases" in cell 13 1154, 

• (ii) the dates for the Initial Balance in cell A3 1155, and for the Final Results in 
cell A71156 

• (iii) the data for the 3 (three) cash transactions to be recorded in the cash 
15 accounting journal in cells A4..E6 1157, while taking advantage of the default 

values (Sale and Book) if applicable. 
Once filled with data, the instance comprises data and results, as illustrated on FIG 
11E. 

However, the user will rapidly need to update the scalable template instance. 
20 Updating such a scalable template instance is also very often complex, lengthy and 
prone to error. Such updates include additions of new elements. Several types of 
modifications can be perfomied without any specific problem in an electronic 
spreadsheet environment. However, this is not the case for an insertion. 

For example, if a row is added through nomial electronic spreadsheet functions such 
25 as the spreadsheet row insertion method, the row created would be empty. This 
means that the value for every field of every element needs to be entered, thus leaving 
the user with heavy data entry or copy/paste workload, while the contents of each element is 
known to a certain extent, and should follow the general structure of the scalable template 
instance. This can be illustrated in our example: let us suppose the user wants to record 
30 another transaction, in the Cash Accounting Journal, for the date 07/05/01, and now referring 
to FIG HE, between rows 1158 and 1159. Inserting a row, through the normal spreadsheet 
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row insertion method, and now referring to HG IIF, will result in a new row 1160, created 
empty, meaning that the value for every field of the element needs to be entered, thus 
leavmg the user with heavy data entry or copy/paste workload, while the contents of each 
element is known to a certain extent, and should follow the general structure defined by the 
5 scalable template, including, in our example, default values of Sale and Book m cells B6..C6 
1161. and formulas m cells F6. .16 1162. Moreover, normal spreadsheet functions such as the 
row insertion function may well jeopardize the contents of some neighbour elements. This 
problem is illustrated with our example, In FIG 1 1F. The fonmula contained in cell F7 
1163 has been changed, by the row insertion operation, to F5+D7-E7, meaning the 
10 new balance is not computed from the balance of the previous row but from the 
balance of the row before the previous row, and will therefore be wrong, as soon as 
data is entered in the newly created element. In this example, not only the user has 
to re-enter the fomnulas in the newly created row, but he also has to check the 
formulas in neighbour elements and to re-enter the corrupted formulas. 

15 In a preferred embodiment of the present invention, a user-friendly solution to these 
problems is proposed by allowing the electronic spreadsheet user to: 
• change an existing scalable template instance by introducing new elements, with 
all predefined fomnats and cx)ntents of each field of the element, while insuring 
the integrity of all elements of the scalable template instance. 

20 The above function is called the "Scalable Template Instance Insertion Manage f 
method, or STUM method for short, and is defined in much further details, in the 
following sections. 

In our example, and now refening to FIG 11G, a new element 1164, with all 
predefined fomnats and contents, is inserted in the existing scalable template 

25 instance, with appropriate default values Sale and Book in cells B6..C6 1165, 
appropriate fomiulas in cells F6..I6 1166, while insuring the integrity of all elements 
of the scalable template instance. This integrity can be illustrated, in our example, 
for which, referring to FIG 110, the fomiula of cell F7 1167 has been changed, by 
the insertion of the new instance element, to F6+D7-E7, meaning the new balance 

30 is appropriately computed from the balance of the previous row. In this example, the 
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user not only avoids re-entering the fonnulas In the newly created element, but also 
avoids checking and correcting the formulas In neighbour elements. 

Deleting an element from a scalable template Instance, deleting a scalable 
template instance 

5 Deleting an element of a scalable template instance also is an operation prone to error. As a 
matter of fact, normal spreadsheet functions such as the row deletion function may well 
jeopardize the contents of some neighbour elements, leading to unresolved references 
producing an error or, even worse, to wrong formulas that may be difficult to identify. This 
can easily be illustrated by our example. Referring to FIG IIG, let us suppose that the user 

10 wants to delete the element on row 6 1164. Now referring to FIG IIH, this wiU result in . 
errors on row 6 1168 (which previously was row 7) and row 7 1169 due to unresolved 
formulas on row 6 1168 because ceUs previously referenced were deleted. Although this 
unresolved reference problem is quite natural in a normal electronic spreadsheet environment, 
it is not justified in a structured envuronment such as the scalable template instance, in which 

IS the knowledge of the structure, where the element deletion happens, allows to properly' 
resolve the updates of the formulas. Solving this problem requires some "context . 
intelligence", taking into account the structure of the scalable template mstance in which the 
element deletion occurs. 

Another need appears when the spreadsheet user selects one or a plurality of cells 

20 and then invokes the conventional Delete function. 

• If the selection does not belong to a scalable template instance, then the 
processing of a conventional Delete function may have some detrimental 
side-effects on existing scalable template instances. Furthermore such 
side-effects may not be clearly visible by the spreadsheet user at the time he/she 

25 invokes the Delete function. A typical example of this situation occurs for 
instance when the spreadsheet user initiates the deletion of a column which has 
a not empty intersection with an existing scalable template instance not visible on 
the display device 106. In this case, the column deletion operation looks safe to 
the spreadsheet user although it will break the structure of the scalable template 

30 instance which is not visible on the display device 106 and which partially 
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overiaps with the column to be deleted. To guarantee that such a delete 
operation will not negatively Impair any existing scalable template instance, the 
spreadsheet user has no other choice than carefully scanning the entire 
spreadsheet (including the part not visible on the display device 106) to 
detennine any risk of scalable template instance corruption. This operation may 
prove to be very difficult, and prone to ^n^ors, especially when existing scalable 
template instancesJncrease in number. 

If the selection belongs to a scalable template instance, calling the Delete 
function by means of a menu or by pressing, the "Delete" key, leaves room to 
ambiguity as to what the user wants to perform. In the current, context of 
electronic spreadsheet environment, where no other tool is really available, this 
must be done by selecting the exact area to be deleted, which may prove to be 
very difficult, especially when manipulated structured ranges of cells increase in 
size and complexity. Solving this probleni requires additional "context 
intelligence" to detect this situation, to take advantage of the structure, of the 
scalable template instance and to offer the relevant choice to the usen The 
possible alternatives are the deletion of the whole . scalable template instance, or 
the deletion of the selected scalable template instance elements, or the deletion 
of the content of the cells within the selectisd scalable template instance 
elements, or the deletion of the content of the cells within the selected range of 
cells. In the two former alternatives, a further distinction must be done to identify 
within the scalable template instance elements the cells belonging to user entry 
fields. Indeed the content of such cells can be cleared without breaking the 
structure of the scalable template instance, while other cells (which typically 
contain fonmulas producing results) must be kept unchanged to preserve the 
integrity of the scalable template instance. To secure this scalable ternplate 
instance integrity, the spreadsheet user has no other choice that carefully 
detemnining, cell by cell, if it carries user-specified information that can be 
cleared, or if it produces a result through a formula that must be preserved. This 
operation may prove to be very difficult, and prone to errors, especially when 
existing scalable template instances increase in size and complexity. 
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In a preferred embodiment of the present invention, a user-friendly solution to these 
problems is proposed by allowing the electronic spreadsheet user to: 

• select what is to be deleted (cells content or scalable template instance element 
or whole scalable template instance), upon the automatic prompt triggered by 

S . calling the conventional Delete function, 

• delete, within a scalable template instance, either the contents of input fields 
within selected cells, or the contents of input fields within selected elements, or 
the whole selected elements, while maintaining the overall integrity of the 
scalable template instance, or 

10 • delete a whole scalable template instance. 

The above function is called the "Scalable Template Instance Deletion Manage/^ 
method, or STIDM method for short, and is defined in much further details, in the 
following sections. 

In our example, and referring to FIG 11G, when one or several cells of row 6 1164 
15 is(are) selected, and when the user calls the deletion function through a menu or by 
pressing the "Delete" key, then the user is prompted to choose between deleting the 
contents of the selected cells, deleting the whole element on row 6 1164, or deleting 
the whole scalable template instance. When the user selects the deletion of. the 
scalable template instance element, the whole element on row 6 1164 is deleted 
20 while maintaining the integrity of the remaining scalable template instance: The 
result of this operation is a scalable ternplate instance with no error, as illustrated on 
FIGilE. 

Refreshing a scalable template instance upon the modification of one of the 
parent element format, element profile, meta-element format or meta-element 
25 profile. 

Once created and used, the scalable templates have their own life cycles, meaning 
that they are created but they also need to be modified by the user. Upon such 
modifications of a scalable template, the need often appears to retrofit those 
changes on existing scalable template instances abiding by the structure of the 
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modified scalable template. This is typically the case of a correction in a fomnula : 
the user wishes to retrofit the changes onto all existing scalable template instances. 
To be more specific, when a user changes a fomiula, in a given field of an element 
profile of a scalable template, most often, he actually wants to change the fomnula in 

S a given field of every element of every scalable template Instance already created 
and every scalable template instance to be created. Once the fomiula in the element 
profile of a scalable template has been changed, the updated fomnula will be 
included in every element of every child scalable template instance to be created. 
On the other hand, changing the fomnula in every element of every scalable 

10 template instance already created should be done manually. It is a long and 
complex operation, requiring a lot of data entry and/or copy-paste operations. This 
operation is not only Jong and complex, but is also prone to errors, especially when 
rhanipulated scalable template instances increase in size, complexity and number. 

This can be illustrated in our example. Now referring to FIG 11J, the user records, in 
15 a new element 1 170, a new transaction : a customer returns a book. The user wants 
to record this transaction as a "negative" sale (the money is.flowing "ouf of the Cash 
Box), by entering the amount in the "$ Ouf field. The user immediately detects that 
the current structure of his Cash Accounting Journal does not support this type of 
transaction : If the Balance is shown correct in cell F7 1171, the Cumulative Sales 
20 arnount, in cell G7 1172, is shown incorrect.. Now referring to FIG 111, this error can 
easily be uriderstood by looking at the formulas contained in the field "Cumulative 
Sales" : the "$ Ouf value is not taken into account. In order to correct this problem, 
the user has to update the fomnula. In this situation, it is obvious that the fomnula 
must not be updated only in the cell G7 1172. It must be updated in the scalable 
25 template itself and in all scalable templates instances abiding by the modified 
scalable template. 

The previous scenario, illustrated so far in the case of a cell containing a fomnula, 
applies if the spreadsheet user wishes to modify the content of a cell con^esponding 
to an entry field within an element profile of a scalable template. Nevertheless some 
30 specific attention must be taken to avoid ovenwrittmg any specific infomnation 
previously filled by the spreadsheet user in an element of an existing scalable 
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template instance which abides by the updated profile definition. For this purpose, 
the spreadsheet user has no other choice than carefully scanning each of these 
elements that abide by the updated profile definition, to detemriine if the entry field 
was already filled by user-specified infonmation (which should be left untouched to 
5 avoid loosing it), or was filled by the defaut content specified in the previous profile 
definition, which can be replaced by the new content specified in the updated profile 
definition, without loosing any user-specified information. 

In a preferred embodiment of the present invention, a user-friendly solution to these 
problems is proposed by allowing the electronic spreadsheet user to: 
10 • Automatically refresh each existing scalable template instance abiding by the 
structure defined in a scalable template, when the parent scalable template is 
updated, through the update of an element format, element profile, meta-element 
fomriat or meta-element profile. 

The above function is called the ''Scalable Template Refresh Managed method, or 
15 STRM method for short,, and is defined in much further details, in the following 
sections. 

Copying-Cutting^asting a scalable template instance 

A scalable template instance is an object that the user needs, at given times, to 
copy-and-paste or cut-and-paste. 
20 The copy-cut function for a scalable tertiplate instance can be perfontied using 
standard spreadsheet function, since the scalable template instance is comprised in 
a range. However, several limitations appear in the standard range copy/cut function 

• The selection of the range conresponding to the scalable template instance is a 
25 mandatory, sometime painful, operation, while it is possible to detect, at the time 
the copy-cut command is issued, that the current cell/selection belongs to a 
scalable template instance, and therefore offer the possibility to copy-cut the 
whole instance. 
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• The standard copy-cut range function does not copy-cut the scalable template 
instance related infonrnation, such as the reference to the parent scalable 
template. This means that rather than copying/cutting a scalable template 
instance, only the range is really copied-cut. 
S • In the case of the cut function, the related entry in the scalable template instance 
table is not removed, as necessary. 

The paste function can, as well, be performed, using standard spreadsheet function. 
However, additional limitations appear in the standard range paste function : 

. • The standard paste function overwrites the previous contents of cells, thus 
10 presenting the risk of loosing infomiation. This, forces the user to make up 
available space for the paste, to avoid loosing data. Making up available space 
requires to determine the exact space necessary. Since the geometry of a 
scalable template instance is known, the process can therefore be automated, 
like it can be automated when a scalable template instance is created. 
15 • The standard paste function would not create the related entry in the scalable 
template instance table necessary to really have a scalable template instance 
rather than a simple range. 

Additionally, the standard range copy/cut and paste function do not allow to paste a 
scalable ternplate instance in lieu and place of another existing scalable tertiplate 
20 instance abiding by the same template. 

Also, at the time the user has selected one or more cells belonging to a scalable 
template instance and calls the copy-cut function, there is an ambiguity as to what 
the user wants to perfomi. He/she may want to copy/cut the content of selected 
cells, copy/cut one or several elements of the scalable template instsince, or 
25 copy/cut the whole scalable template instance. 

Finally, as the user copies-cuts/pastes, ranges of the spreadsheet that do not belong 
to a scalable template instance, there is a value to protect the integrity of existing 
scalable template instances, from any side effect. 
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In a preferred embodiment of the present Invention, a user-friendly solution to these 
problems is proposed by : 

• allowing the electronic spreadsheet user to : 

• copy/cut a scalable template instance, 

5 • paste a scalable template instance in lieu and place of another existing 
instance, 

• paste a scalable template Instance in any other area of the spreadsheet, after 
automatically preparing the necessary space to protect preexisting data, 

• copy/cut one or several scalable template instance elements, 
10 . • paste one or several scalable template instance elements, 

• automatically detecting that the current cell or selection is in a scalable template 
instance, and offering the user the options to copy-cut a scalable template 
instance or scalable template instance elements rather than a cell or range. 

The above set of functions is supported by a set of tools : the "Scalable Template 
15 Instance Copy Manager", the ''Scalable Template Instance Cut Managed and 
the "Scalable Template Instance Paste Managed methods, or STICopyM, 
STICutM, and STIPasteM methods for short. This set of tools is described in rifiuch 
further details in the following sections. 

Exporting and importing element/meta-element formats/profiles and scalable templates. 

20 As the user defines, in a given spreadsheet file, a set of element formats, 
meta-element fomnats, element profiles, meta-element profiles, and scalable 
templates (further referred to as scalable templates items), he is really developing 
an intellectual capital that may result from important development efforts, and may 
therefore carry a high value for the user. It is not unusual that this set of developed 

25 scalable template items, or a subset of it, can be useful in another spreadsheet file. 
In such a case, the user would waste a considerable amount of energy if he had to 
develop again the same set of template items. Copy/paste operations is, of course, 
an alternative, but individual copy/paste operations of such template items may 
indeed be in Itself a huge operation. 
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In a preferred embodiment of the present invention, a user-friendly solution to this 
problem is proposed by allowing the electronic spreadsheet user to: 

• Export scalable template items (i.e. elemerit formats, element profiles, 
meta-element fonrnats, meta-element profiles and. scalable templates) from a 

S . spreadsheet file, 

• Import scalable template items (i.e. element formats, element profiles, 
meta-element fonmats, meta-element profiles and scalable templates) into a 
spreadsheet file, 

and, therefore, be able to reuse, in any spreadsheet file, the set of scalable 
10 templates items, that have been defined in any other spreadsheet file. 

The above set of functions is supported by a set of topis : the ''Scalable Template . 
Export Manage/^ method, or STEM method for short, and the ''Scalable Template 
Import Managed method, or STIM method for short, and is described in much 
further details in the following sections. 

IS Exporting and importing the IN (or data) portion of scalable templates instances. 

During their own life cycle, scalable template instances will grow in size and the 
amount of data stored to. save such a scalable template instance may becorne 
. prohibitive. This is tnie while, on the. other hand, it is obvious that an important portion of 
. each element of scalable template instances may be constituted of OUT fields only 

20 comprising formulas, without any source, or essential data. Those fields, being similar from 
element to element, actually comprise redundant information, not redundant fix)m an end user 
prospective, since it certainly is useful to display results or intermediate results, but redundant 
from an essential prospective because it can be recreated fiom the base structure information 
of the scalable template instance; i.e. scalable template, element format, element profile, 

25 meta-element format, meta-element profile. Storing and/or conveying this redundant 
information is a waste that could be avoided . if a mechanism would allow to only 
store/convey the informative data and the base stmcture information. . 
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In order to solve this problem, there is value in making a clear and fomial distinction 
between IN fields aimed at receiving raw or informative data from the user and OUT 
fields, most often containing fixed values or formulas, aimed at providing results or 
intermediate results to the user. 

S In our example, and now referring to FIG 11 B, when considering the scalable 
template instance illustrated, the cells A3..A8 1127, B4..E7 1128, and F3..I3 1129, 
are aimed at containing IN data. Other cells of the scalable template instance are 
aimed at providing results, using fixed content or fomnulas defined in the scalable 
template. 

10 In a preferred embodiment of the present invention, a user-friendly solution to thi$ 
problem is proposed by allowing the electronic spreadsheet user to: 

• export the IN (or infonnative) data of a scalable template instance, 

• import the previously exported IN (or infomnative) data of a scalable template 
instance, into another scalable template instance. If this previously exported IN 

15 data is imported into a scalable template instance abiding by the same structure, 
i.e. with the same parent scalable template, and with the same number of 
elements, it will reconstitute an exact copy of the original scalable template 
instance. The previously exported IN data may also be imported Into another 
scalable template instance, abiding by a slightly different structure. There is 

20 value in perfomiing such an operation, as; long as the IN data is relevant in the 
import scalable template instance. There is, therefore, vajue in allowing such an 
operation. 

The above capability results in significant user time, transmission time and storage 
space savings, and therefore in important cost savings. This also facilitates remote 
25 collaboration through file exchange. 

In our example, and referring again to FIG 1 1B, the IN data of the scalable template 
instance illustrated, i.e. the content of the cells A3..A8 1127, B4..E7 1128, and F3..I3 
1129, can be exported, stored and conveyed. This limited set of data, together with 
the parent scalable template of the instance, contains all the information necessary 
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to recreate the original scalable template instance. This limited set of data can then 
be imported into another scalable template instance (thus reconstituting an exact 
copy of the original scalable template instance if the import scalable template 
instance abides by the same parent scalable template and has the same number of 
S elements than the original instance). 

The above set of functions is supported by a set of tools : the "Scalable Template 
Instance Export Managef method, or STIExportM method for short; the "Scalable 
Template Instance Import; Managed method, or STIImportM method for short. 
This set of tools is described in much further details in the following sections. 

10 Usinp a sort application with scalable template instances 

Sorting data in a spreadsheet environment, and more specifically in a structured range of cells 
is a quite natural, often necessary operation. Considering existing tools and prior art, within 
an electronic spreadsheet environment, this operation can be performed, by the user, who first 
selects a range of cells and, then, calls the standard sort application. When performed in a ' 

15 spreadsheet comprising scalable template instances, the sort operation may introduce errors or 
break the consistency of a scalable template instance. This is the case if the range of cells 
selected prior to the caU to the sort function (for example A1..K92) overlaps the range 
occupied by a scalable template instance (for example H70..N105). This is also the case if the 
range of cells selected prior to the call to the sort function overlaps the body and the footer of 

20 a scalable template instance. Moreover, at the time the user has selected one or rnore 
cells belonging to a scalable template instance and calls the sort application, there is . 
. an ambiguity as to what the user wants to\ perform. He/she may want to sort the 
contents of selected cells, sort, one or several elements of the scalable template 
instance, or sort the whole scalable template instance. 

25 Sorting a whole scalable template instance is a useful operation. However, to make it a 
meaningful operation, i.e. respect the structure of the scalable template instance, only element 
of the body must be sorted. 

In our example, one simple sort application that could be used with aU Cash Accounting 
Journals, is a "Date sorting" application. Now referring to FIG llj, this date sorting 
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application must sort the elements of the Cash Accounting Journal, in ascend order, on the 
range A4..A7 1173. 

In a preferred embodiment of the present invention, a user-friendly solution to this 
problem Is proposed by allowing the electronic spreadsheet user to: 
5 • sort ranges within the spreadsheet file, while protecting the consistency of 
existing scalable template instances, 

• sort several elements of a scalable template instance, 

• sort a whole scalable template instance (i.e. all elements of the body part of a 
scalable template instance). 

10 The above function is referred to as the ""Scalable Template Instance Sort 
Application Manage!^ method, or S7/S>l/W method for short, and Is defined in much 
further details, in the following sections. 

B. Concepts and Vocabulary 

The purpose of this section is to fomialize both some concepts (with associated 
15 objects) and some vocabulary defined vi/ithin the scope of the present Invention. In 
the following descriptions, it is assumed that spreadsheets are in two dimensions 
(2D), so that tables and structures can be described in a 2D environment. Moreover 
it is assumed that tables are organized vertically, so that the table headings are on 
the top of the table instead of being on its left. This allows to significantly clarify the 
20 description of the various original concepts, objects, and methods which are part of 
the present invention, but this does not limit in any way the scope of the invention. In 
other words, the underneath description can be generalized to environment with 
either 2D tables organized horizontally or with 3D tables, without departing from the 
spirit of the present invention. 

25 B1. Preliminary Definitions 

Structured Range of Cells : a structured range of cells is a range of cells that abides by 
some kind of structure organising the data into rows and columns. Columns define fields 
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aimed at containing the same kind of infonnation on each row. Rows define records (or 
elements). 

Table : the won! table can be used to designate a structured range of ceUs. 

Field : a field is a labeled column in a database or table that contains the same kind of 
5 information for each record (or element). For example, a customer table may contain fields 
labeled Name, Address and Tel #. 

By. extension, in a given record (or element), a given field refers to the cell located at the 
intersection of the record (or element) and the given field (labeled colunin). 

The above definitions are for a 2D environment where columns define fields and rows define 
10 . records. They can be transposed in a 2D environement where rows define fields and columns 
. define record. They can also be transposed in a 3D environment, where, for example, sheets 
define repords. 

IN/OUT Cell : a cell is specified as "IN" cell when assumed to. be used for recording 
user provided infonmation. A cell Is specified as ''OUT" cell when assumed to be 
IS used for producing information (generally obtained through . fonmulas Whose 
arguments refer directly or indirectly to "IN" cells). . 

B2. Object Definitions 

The following objects are defindd to help the understanding of the invention. 

Element Format : an element format is a spreadsheet object defining the structure 
20 of an element within a 2 dimensions or a 3 dimensions range of cells, in terms of 
format attribute : 

• Background attributes (color, pattem, etc.), 

• Alignment attributes (horizontal, vertical, text wrapping, alignment across 
columns, etc.) 

25 • Font attributes (size, color, etc.) 

• Line attributes (type, color, etc.) 
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• Protection of the field 

• and any other conventional format attribute. 

Example : Referring now to FIG. 3, an element fonmat EF„Body 301 could 
define the structure of a 2 dimension range as a 3 field table, where the first 
5 field is with bold font, left justified ; where the second field is with nomial font, 
left justified ; and where the third field is with nomial font, centered. 

Meta-Element Format : a meta-element fomiat is. a spreadsheet object defining the 
stmcture of a meta-element within a 2 dimensions or a 3 dimensions range of cells, 
in terms of fonmat attribute : 
10 • Background attributes (color, pattern, etc.), 

• Alignment attributes (horizontal, vertical, text wrapping, cell merging, etc..) 

• Font attributes (size, color, etc..) 

• Line attributes (type, color, etc..) . 

• Protection of the field 

15 • and any other conventional fomiat attribute. 

Example : A meta-element format MEF_Header 302 could define the structure 
of a 2 dimensions range by defining It as a 3 column, single row structure 
made of three fields, each field being bordered by a solid line. 

Example : A meta-element fomiat MEF_Yellow 303 could define the structure 
20 of a meta-element part of a 2 dimensions range by defining it as a 3 cell 

structure, all with yellow background color, and where the two left most cells 
are aligned across columns (a.k.a. ''merged cells"). 

Element Profile : an element profile is a spreadsheet object defining the structure of 
an element within a 2 dimensions or a 3 dimensions range of cells, in temis of 
25 content and destination : 

• fomiulas for fields to be computed from data comprised in other fields of 
the same element, or in other fields of another element or meta-element 
of the same instance, or even in other fields outside the instance. 
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• field default values to be assigned at element creation time. 

• destination of the cells (data entry for "IN" cells or data produced for 
"OUT" cells). 

Example : An element profile EP^Body 304 could define the structure of a 2 
5 dimension range as a 3. fields table, where the first field has a default value 

"New Name", where the second field has a default value "New First Name" 
and where the third field has a void default value. 

Meta-Element Profile : a meta-element profile is a spreadsheet object defining the 
structure of a meta-element within a 2 dimensions or a 3 dimensions range, in temns 
of content and destination : 

• fonnulas for cells to.be computed from data comprised in other cells of the 
same element, or in other cells of another element or meta-element of the 
same instance, or even in other cells outside the instance. 

• cell default values to be assigned at meta-element creation time. . 

• destination of the cells (data entry for "IN" cells or data produced for 
"our cells) 

. Example : A meta-element profile MEP^Header 305 could define the structure 
of a 2 dimensions range by defining it as a 3 cell structure, the leftmost cell 
being filled with the content "Family name", the middle cell being filled with 
20 . the content "First Name", and the rightmost cell being filled with the content 
"Age". All these three cells are "OUT' cells. 

Example : A meta-element profile MEP_Average 306 could define the 
structure of a 2 dimenisions range by defining It as a 3. ceil structure, the 
leftmost cell being filled with the content "Average", the middle cell being filled 
25 with a void content, and the rightmost cell containing a formula computing the 

average value of the rightmost field of the elements within the instance. All 
these three cejls are "OUT cells. 
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Scalable Template (also referred to as "Template") : A scalable template Is a 
spreadsheet object defining the structure of a 2 dimensions or a 3 dimensions range 
of cells, in tenns of {element + meta-elements} layout. The word "scalable" refers to 
the capability of the scalable template of defining a given stmcture for variable size 
5 (e.g. ranging from a minimum value to a maximum value) range of cells. The 
scalable template defines a structure by : 

• specifying the number of fields, 

• by refening to a couple of element fonmat and/or element profile that defines 
each body element, and, 

10 • optionally, by referring to one or several couples of meta-element formats 
and/or meta-element profiles. 

In a 2 dimensions environment, such meta-element formats / profiles are either 
located above the element fonmat / profile, constituting the scalable template 
"header^ part, or located below the element fonriat / profile, constituting the scalable 
15 template "footer" part. Either the scalable template "header" part or the scalable 
template "footer" part, or both of them may be empty. 

When the element and meta-element references are only constituted by element 
profiles and meta-element profiles, then the scalable template only carries contents 
infonmation and can thus be named Scalable jProfiled Template. 

20 When the element and meta-element references are only constituted by element 
fomnats and meta-element formats, then the scalable template only carries format 
infonmation and can thus be named Scalable Formatted Template. 
When the element and meta-element references are constituted by any combination 
of both profiles and fonmats, then the scalable template carries both profile and 

25 fonmat Infonmation and can thus be named Scalable Profiled & Formatted 
Template. 

Example : A scalable template SFT^A 307 could define the structure of a 2 
dimensions range by defining a three column (referred to as A, B, C) structure 
made by a top meta-element fomiat MEF^Header 302 (the "header" part), a 
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middle element fomiat EF_Body 301 and a bottom meta-element fomiat 
MEF^Yellow 303 (the "footer" part). 

Example: A scalable template SPT_A 308 could define the staicture of a 2 
dimensions range by defining a three field (referred to as A, B, C) structure made 
5 by a top meta-element profile MEP^Header 305 (the "header" part), a middle 
element profile EP^Body 304 and a bottom meta-element profile MEP^Average 
306 (the "footer part). 

Example : A scalable template SPFT„A 309 could define the staicture of a 2 
dimensions range by defining a three field (refenred to as A, B, C) structure made 

10 by a top meta-relement format MEF^Header 302 coupled with a top 
meta-element profile MEP^Header 305 (both constituting the "header" part), a 
middle element format EF_Body 301 coupled with a middle element profile 
EP^Body 304 and a bottom meta-element fomiat MEF_Yellow 303 coupled with 
a bottom meta-element profile MEP_Average 306 (both constituting the "header" 

15 . part). 

Scalable Template Instance (also referred to as "Instance" or "scalat)le instance") : 
A scalable instance is a spreadsheet object abiding by the structure of a defined 
scalable template : a scalable fomiatted template, or a scalable profiled template, or 
a scalable profiled & fomriatted template. An instance may be viewed as a child 
20 object of the scalable template. It contains a variable number of elements (at least 
one) containing infomiation, in each field, corresponding to the pairent structure, and 
constituting the "body" part, plus optionally one or several meta-elements. as defined 
by the scalable template, and constituting the "header" part and the "footer" part of 
the scalable template instance. 

25 Example : Referring now to FIG 4, an instance SFTLA 401 is created, with a 
specified number of 3 elements structured according to the scalable fomiatted 
template SFT_A 307. The instance SFTLA 401 is then a 2 dimensions table, 
with 3 columns, made of three parts. The top "header"' part is a meta-element 
ME_Header 402, abiding by the meta-element fomiat MEF_Header 302, made 
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of three cells, all bordered with a solid line. The second "body" part is a 3 column 
wide table made of a variable number of elements (3 in the example), all abiding 
by the element fonnat EF_Body 301 , so that the first field Is with bold font, left 
justified ; the second field is nomnal font, left justified ; and the third field is 

5 nornial font, centered. The bottom "footer" part is a meta-element ME.Yellow 
403 abiding by the meta-element fonnat MEF_Yellow 303, made of three cells, 
all with yellow background color. Each element of the instance (within the middle 
"body" part) would be 3 column wide. A variable number (between minimum and 
maximum size) of elements, initially empty, could be added to the instance 

10 SFTLA4Q4 and filled by the user. 

Example: An instance SPTLA 405 Is created, with a specified number of 3 
elements structured according to the scalable profiled template SPT_A 308. The 
instance SPTLA 405 would then be a 2 dimensions table, with 3 columns, made 
of three parts. The top "header part is a meta-element ME_Header 406, abiding 

15 by the meta-element profile MEP_Header 305, made of three cells, respectively 
filled with contents "Family Name", "First Name" and "Age". The second "body" 
part is a 3 column wide table made of a variable number of elements (3 in the 
. example), all abiding by the element profile EP_Body 304, respectively initialised 
with default values "New Name", "New First Name" and void. The bottom "footer" 

20 part is a meta-element ME_Yellow 407 abiding by the meta-element profile 
MEP_Average 306, made of three cells, respectively filled with contents 
"Average", void, "@INSTAVE(#samecol)". Each element of the instance (virithin 
the middle "body" part) would be 3 column wide. A variable number (between 
minimum and maximum size) of elements, initially filled with default values, could 

25 . be added to the instance SPTIJ^ 408, and then filled by the user. 

Example: An instance SPFTI_A 409 is created, with, a specified number of 3 
elements structured according to the scalable profiled & fomnatted template 
SPFT_A 309. The instance SPFTI_A 409 would then be a 2 dimensions table, 
with 3 columns, made of three parts. The top "heiader" part is a meta-element 
30 l\/IE_Header 410, abiding by the meta-element forniat IVlEF.Header 302 and the 
meta-element profile MEP_Header 305, made of three cells, all bordered with a 
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solid line, respectively filled with contents Tamily Name^ Tirst Name" and 
"Age". The second "body" part is a 3 column wide table made of a variable 
number of elements (3 in the. example), all abiding by the element forniat 
EF_Body 301 and the element profile EP.Body 304, respectively initialised with 

5 default values "New Name", "New First Name" and void, and so that the first field 
is with bold font, left justified ; the second field is nonmal font, left justified ; and . 
the third field is nomnal font, centered. The bottom "footer" jDart is a meta-element 
ME_Yellow 411 abiding by the meta-element format MEF^Yellow 303 and a 
meta-element profile MEP.Average 306, made of three cells, all with yellow 

10 background color, respectively filled with contents "Average", void. 
"@INSTAVE(#samecol)". Each element of the instance (within the middle "body" 
part) would be 3 column wide. A variable number (between minimum and 
maximum size) of elements, initially filled with default values, could be added to 
the instance SPFTLA 412 and then filled by the user. 

15 Element : An element is a spreadsheet object belonging to a scalable instance, and 
made of elementary fields abiding either by an element format, or by an element 
profile, or by a couple (element template, element profile) found in the parent 
structure (respectively scalable fonnatted template, or scalable profiled template, or 
scalable profiled & fomnatted template). Without loosing any generality, it. is 

20 assumed that an element always abides by a couple (element template, islement 
profile), where either the element template or the element profile can be reduced to 
a void object. 

Example : An element of instance SFTLA 404 can contain "Aureglia" in the first 
element field, "Jean-Jacques" in the second element field and "42" in the third 
25 element field. A similar element could be found in other instances like SPTLA 
408 and SPFTLA 412. 

Meta-Element : A meta-element is a spreadsheet object belonging to an instance, 
and made of elementary cells abiding either by a meta-element fonnat, or by a 
meta-element profile, or by a couple (meta-element template, meta-element profile). 
30 Without loosing any generality, it is assumed that a meta-element always abides by 



45 



wo 03/014987 



PCT/EP02/09483 



a couple (meta-element template, meta-element profile), where either the 
meta-element template or the meta-element profile can be reduced to a void object. 

Example : In the scalable template Instance SFTLA 404, a meta-element 
ME_Header 413 is abiding by the MEF_Header 302 meta-element fomiat, and a 
5 meta-element ME^Yellow 414 is abiding the MEF^Yellow 303 meta-element 
format. 

All the objects introduced above can be advantageously arranged in a positioning 
diagram, as shown in FIG 5. Element fonmats 501, meta-element fomiats 502, 
element profiles 503, meta-element profiles 504 are part of scalable templates 505, 
10 or 506 or 507. In turn elements 508 or 509 or 510 and meta-elements 511 or 512 or 
513 are respectively part of scalable template instahces 514 or 515 or 516 which 
respectively abide by scalable templates 505 or 506 or 507. 

C. Tables used for managing Scalable Template objects 

As introduced in the previous section, the preferred embodiment of the present 
IS invention relies on different types of objects for managing scalable templates. These 
objects are recorded in different repositories, so that they can be accessed and 
updated by the different methods which are part of the prefen^ed embodiment of the 
present invention. Such repositories are referred to as tables: 

• the Element Format Table or EFT for short, 
20 • the Element Profile Table or EPT for short, 

• the Scalable Template Table or STT for short, 

• the Scalable Template Manager Table or STMT for short. 

• The Scalable Template Descriptor Table or STDT for short. 

• The Scalable Template Instanciator Table or ST/T for short. 
25 • The Scalable Template Export-Import Table or STEITiox short. 

• The Scalable Template Instance Export-Import Table or STIEIT for short. 

• The Exported Scalable Template Instance Table or ESTITior short. 
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The EFT, EPT, STT, STDT and Sr/T tables are saved as part of the spreadsheet 
disk file on the nnass storage 107, whereas the STMT table is temporarily saved on 
the main memory 102 and the STEFt, STIEIT and ESTFT tables are saved on 
spreadsheet export-import files and spreadsheet instance export-import files. 

5 CI. Element Format Table 

Refening now to FIG. 7A, the EFT Table TOO corresponds to a logical simple 
structure made of several records 701, each of them corresponding to an element 
fomiat or to a meta-element format, according to the present invention. Each record 
includes six fields: 

10 • The "Name" 702 field is used for recording a character string which uniquely 
identifies the element format or. the meta-element format described by the 
current record 701. 

• The "Last Change Date" 703 field is used for recording the date of the last . 
update of the element format or the meta-elernent fomiat described by the 

15 current record 701. 

• The "Description Ptf 704 field is a reference pointing to the memory location 
where is recorded an illustrative range of cells depicting the element fomriat or 
meta-element fomiat described by the current record 701. This memory location 
can either be on the Mass storage 107, or on the main memory 102, or on other 

20 conventional memory repository means, without departing from the spirit of the. 
present invention. 

• The "Row #"705 field is used for recording the number of rows present in the 
element format or in the meta-element fomriat described by the current record 
701. This field is relevant for 3D scalable templates where element or 

25 meta-element fonnats correspond to 2D structures. In the preferred embodiment 
of the present invention where 2D scalable templates are assumed, this field is 
always filled with the value 1 . 
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• The "Column #^706 field is used for recording the number of columns present in 
the element fomnat or in the meta-element fomnat described by the current record 
701. 

• The Type" 707 field is used for recording different attributes associated to the 
5 element fonnat or to the meta-element fomnat described by the current record 

701: this is the ''meta" attribute 708 specifying if the cun'ent record 701 describes 
an element format or a meta-element fomnat (with respective values "no" and 
"yes"); and the "referenced" attribute 709 specifying If there is at least one 
scalable template or at least one scalable template instance or none of them 
10 which refers to this element fomnat or meta-element fomnat (with respective 
values "template", "instance" and "none"). Conventional techniques can be used 
for encoding these different attributes in this "Type" field, such as executing 
bit-wise XOR operations with predefined bit patterns, but any other conventional 
means could be used instead without departing from the spirit of the invention. 

IS C2. Element Profile Table 

Referring now to FIG. 7B, the EPT Table 710 corresponds to a logical simple 
stmcture made of several records 711, each of them corresponding to an element 
profile or to a meta-element profile, according to the present invention. Each record 
includes six fields: 

20 • The "Name" 712 field is used for recording a character string which uniquely 
identifies the element profile or the meta-element profile described by the current 
record 711. 

• The "Last Change Date" 713 field is used for recording the date of the last 
update of the element profile or the meta-element profile described by the 

25 current record 71 1 . 

• The "Description Ptr^ 714 field is a reference pointing to the memory location 
where an illustrative range of cells depicting the element profile or meta-element 
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profile described by the current record 711 is recorded. This memory location 
can either be on the Mass storage 107, or on the main memory 102, or on other 
conventional memory repository means, without departing from the spirit of the 
present invention. 

S • The '^Row #"715 field is used for recording the number of rows present in the 
element profile or in the meta-element profile described by the current record 
711. This field is relevant for 3D scalable templates where element or 
meta-element profiles correspond to 2D structures. In the prefenred embodinient 
of the. present invention where 2D scalable templates are assumed, this field is 
10 always filled with the value 1 . 

• The "Column #"716 field is used for recording the number of columns present in 
the element profile or in the meta-element profile described by the cun'ent record 
711. 

• The Type" 71 7 field is used for recording different attributes associated to the 
15 element profile or to the meta-element profile described by the current record 

711: this is the "meta" attribute 718 specifying if the cunrent record 701 describes, 
an element profile or a meta-element profile (with respective values "no" and 
**YEs"), and the "referenced" attribute 719 specifying if there is at least one 
scalable template or at least one scalable template instance or none of them 
20 which refers to this element profile or meta-element profile (with respective 
values '^template", "instance" and "none"). Conventional techniques can be used 
for encoding , these different attributes in this "Type^ field, such ais executing 
bit-wise XOR operations with predefined bit pattems, but any other conventional 
means could be used instead without departing from the spirit of the invention. 

25 C3. Scalable Template Table 

Referring now to FIG. 7C, the S7T Table 720 corresponds to a logical simple 
structure made of several records 721, each of them corresponding to a scalable 
template, according to the present invention. Each record includes six fields: 
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• The "Name" 722 field is used for recording a character string which uniquely 
identifies the scalable template described by the current record 721 . 

• The "Last Change Date" 723 field is used for recording the date of the last 
update of the scalable template described by the current record 721 . 

5 • The "Description Ptf 724 field is a reference pointing to the memory location 
where a description of the scalable template described by the current record 721 
is recorded. This memory location can either be on the mass storage 107, or ori 
the main memory 102, or on other conventional memory repository means, 
without departing from the spirit of the present invention. This description is 

10 structured according to the STDT table 760 illustrated in FIG 7E, that is as an 
ordered list of couples of names, each couple being made by the name of an 
element or meta-element format and by the name of an element or meta-element 
profile. 

• The "Min Element 725 field is used for recording the minimum number of 
IS elements found in every scalable template instance abiding by the scalable 

template described by the cunrent record 721 . 

• The "Max Element #" 726 field is used for recording the maximum number of 
elements found in every scalable template instance abiding by the scalable 
template described by the cun^nt record 721 . 

20 • The Type" 727 field is used for recording different attributes associated to the 
scalable template described by the current record 721 : this is the "meta" attribute 
728 which always take the value "no", and the "referenced" attribute 729 
specifying if there is at least one scalable template instance or none of them 
which refers to this scalable template (with respective values "instance" and 

25 "none"). Conventional techniques can be used for encoding these different 
attributes in this "Type^ field, such as executing bit-wise XOR operations with 
predefined bit patterns, but any other conventional means could be used instead 
without departing from the spirit of the invention. 
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C4. Scalable Template Manager Table . 

Referring now to FIG. 7D, the STMT Table 730 corresponds to a logical simple 
stmcture made of several records 731, each of them con^sponding to an object 
managed by the scalable template manager, according to the prefen'ed embodiment 
5 of the present invention. Each record includes seven fields: 

• The "Name" 732 field is used for recording a character string which uniquely 
identifies the object described by the current record 731 . 

• The "Last Change Date" 733 field is used for recording the date of the last 
update of the object described by the current record 731 . 

10 • The "Description Ptr" 734 field is a reference pointing to the memory location 
where is recorded a description of the object described by the current record 
731. This memory location can either be on the Mass storage 107, or on the 
main memory 102, or on other conventional memory repository means, without 
departing from the spirit of the present invention. 

15 • The "Info Field 7". 735 field is used for recording a first piece of infomiation 
associated to the object described by the current record 731 . 

• The "Info Field 2" 736 field is used for recording a second piece of information 
associated to the object described by the cun-ent record 731 . 

• The "Type" 737 field is used for recording different attributes associated to the 
20 . object described by the current record 731, such as the attributes "meta" 739 and 

"referenced" 740 previously described for the similar "TypeT fields 707, 717 and 
727, and also two other attributes: 

• the "selected" attribute 742 reflecting whether the associated object has been 
or not selected by the spreadsheet user within the Scalable Template 
25 Manager Dialog Box 600, (with respective values "yes" and "no"), and also 
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• the "nature" attribute 741 reflecting wliether tine object is a "format", or a 
"profile", or a "^mplate" (with respective values "formal, "profile", and 
"tempute"). 

Conventional techniques can be used for encoding these different attributes in 
5 this "Type^ field, such as executing bit-wise XOR operations with predefined bit 
patterns, but any other conventional means could be used instead without 
departing from the spirit of the invention. 

• The ''lnde)C 738 field is used for sorting the STMT table, as perfomied by the 
Scalable Template Manager \x\ethod. 

10 C5. Scalable Template Descriptor Table 

. Referring now to FIG. 7E, the STDT Table 760 corresponds to a logical simple 
structure made of several couples of element or meta-element format 765 and of 
element or meta-element profile 764. This structure is organised into three sub-sets: 

. • The optional scalable template "Header" part 767, made of a variable number 
15 (possibly null) of couples like the top couple 761. Each of these couples is 
constituted by a meta-element ^fomaat (column 765) and by a hneta-element, 
profile (column 764). 

• The mandatory "Body" part 762 made of a single couple constituted by an 
element fomiat (column 765) and by an element profile (column 764). 

20 • The optional scalable template "Footei^ part 766, made of a variable number 
(possibly null) of couples like the bottom couple 763. Each of these couples is 
constituted by a meta-element format (column 765) and by a meta-element 
profile (column 764). 

C6. Scalable Template Instanciator Table 
25 Referring now to FIG. 7F, the STIT Table 750 corresponds to a logical simple 
structure made of several records 751, each of them corresponding to a scalable 
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template instance, according to the preferred embodiment of tlie present invention. 
Each record includes six fields: 

• The "Address" 752 field is used for locating the scalable template instance 
described by the current record 751: its value con^sponds to the conventional 

5 character string used to record the address of any range of cells. 

• The "SV 753 fi^ld is used for recording the name of the scalable template 
abided by the scalable template instance described by the current record 751 . 

• The "Element #"754 field is used for recording the number of elements within the 
scalable template instance described by the current record 751 . 

10 • The "Criticar 755 field is used for recording if the scalable template instance 
described by the current record 751 is considered as critical. Its content can take 
the values 'Ves" or "no", 

• The "Header Size" 756 field is used for recording the number of meta-elements 
constituting the Header part of the scalable template instance described by the 

. 15 cunrent record 751 . 

• The -Footer Size" 757 field is used for recording the number of meta-elements 
constituting the Footer part of the scalable template instance described by the 
current record 751. 

C7. Scalable Template Export-Import Table 

20 Referring now to FIG. 7G, the STEIT Table 770 con-esponds to a logical simple 
stmcture made of several records 771, each of them corresponding to an exported 
scalable template item (element format or meta-element fonnat or element profile or 
meta-element profile or scalable template) managed by the scalable template export 
manager or by the scalable template import manager, according to the preferred 

25 embodiment of the present invention. Each record includes seven fields: 
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• The "Name" 772 field is used for recording a character string which uniquely 
identifies the object described by the cun^ent record 771. 

• The "Last Change Date" 773 field is used for recording the date of the last 
update of the object described by the current record 771 . 

5 • The "Description Ptf 774 field Is a. reference pointing to the memory location 
where a description of the object described by the current record 771 is 
recorded. This memory location can either be on the Mass storage 107, or on the 
main memory 102, or on other conventional memory repository means, without 
departing from the spirit of the present invention. 

10 • The "Info Field 1" 775 field is used for recording a first piece of information 
associated to the object described by the current record 771 . 

• The "info Fieid 2" 776 field Is used for recording a second piece of information 
associated to the object described by the current record 771 . 

• The "Type" 777 field is used for recording different attributes associated to the 
15 object described by the current record 771, such as the attributes "meta" 779, 

"referenced" 780, "selected" 782, and "nature" 781 . 

Conventional techniques can be used for encoding these different attributes in 
this "Type" field, such as executing bit-wise XOR operations with predefined bit 
patterns, but any other conventional means could be used instead without 
20 departing from the spirit of the invention. 

• The "/ndeV' 778 field is used for scanning the STE/T table, as performed by the 
Scalable Template Export Manager and Scalable Template Import Manager 
methods. 

C8. Scalable Template Instance Export-Import Table 

25 Referring now to FIG. 7H, the STIEIT Table 790 corresponds to a logical simple 
structure made of several records 791, each of them corresponding to an exported 
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scalable template instance managed by the scalable template instance export 
manager or by the scalable template Instance import manager, according to the 
preferred embodiment of the present invention. Each record includes five fields: 

• The "Name" 792 field is used for recording the name of the range of cells 
S con^esponding to the exported scalable template instance described by the 

current record 791. 

• The "Source File Name" 793 field is used for recording the name of the file from 
which has been performed the last export operation for the exported scalable 
template instance described by the current record 791 . 

10 • The "Export Date" 794 field is used for recording the date of the last export, 
operation for the exported scalable template instance described by the current 
record 791.. 

• The "Row #^795 field is a reference pointing to the memory location where is 
recorded the ESTIT table containing the exported scalable template instance 

15 described by the current record 791. This memory location can either be on the 
Mass storage 107, or on the main memory 102, or on other conventional memory 
repository means; without departing from the spirit of the present invention. 

• The "Exported STI Ptr" 796 field is used for recording a first piece of infomijation 
associated to the object described by the current record 791 . 

20 C9. Relationships Between Tables 

Referring now to FIG. 71, some previously introduced tables STIT 750, STT 720, 
STDT 760, EFT 700 and EPT 710 are presented altogether to illustrate the 
relationships established between these tables. 

• Starting with a scalable template instance 797 made of the three parts Header, 
25 Body and Footer, a first relationship is established between this scalable 

template instance 797 and a record 751 of the STIT table 750. 
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• A second relationship Is then established between this record 751 and a record 
721 of the SIT table 720. This record 721 coresponds to the scalable template 
abided by the scalable template instance 797. 

• A third relationship is established between this record 721 and a STDT table 760 
5 which describes the structure of the scalable template. Each record of the STDT 

table 760 corresponds to a pair of an element or meta-element fonmat name and 
of an element or meta-element profile name. 

• A fourth relationship is established between the element or meta-element format 
name and a record 701 of the EFT table 700. 

10 • A fifth relationship is established between the element or meta-element profile 
name and a record 71 1 of the EPT table 71 0. 

• A sixth relationship is established between the record 701 and an illustrative 
range of cells 798 specifying the format attributes. 

• A seventh relationship is established between the record 71 1 and an illustrative 
15 range of cells 799 specifying the profile content. 

CI 0. Exported Scalable Tennplate Instance Table 

Referring now to FIG. 27C, the EST/T Table 2740 corresponds to a logical simple 
structure made of several records 2741, each of them corresponding to a row of an 
exported scalable template instance managed by the scalable template instance 
20 export manager or by the scalable template instance import manager, according to 
the pretended embodiment of the present invention. The ESTIT table can thus be 
seen as the range of cell which results from the disappearance of "OUT'. fields from 
a scalable template instance. Each record includes two fields: 

• The "Field #"2742 field is used for recording the number of "IN" fields recorded in 
25 the range of cells corresponding to the 2743 field. 

• The "Field Contenf 2743 field is a conventional range of cells corresponding to 
the concatenation of the "IN" field cells for the row of the exported scalable 
template instance described by the current record 2741 . 

D. Scenarios 
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In contrast to just-described conventional tools, the pretended embodiment oif the 
present invention provides a more powerful, user-friendly and interactive approach 
for defining and managing scalable templates, in a fomi of a collection of methods. 

In a preferred embodiment, the present invention is used within a scenario which 
5 articulates as a sequence of operations : 

• 1. First Operation : Creation of a Scalable. Template instance 

The first operation occurs when the spreadsheet user decides, based on some 
criteria not detailed here, to create a scalable templiate instance abiding by the 
structure of a scalable template. In a prefen^ed. embodiment of the present 
10 . invention, this operation comprises the following steps: 

• a. Scalable Template Manager 

The spreadsheet user invokes first an original specif ic . command called . 
"Scalable Template Manage!'' thanks to conventional means available in 
spreadsheet environment, such as but not limited to the pointing device 105 
15 or the keyboard 104, in order to visualise through a dedicated user interface 

any existing element format or meta-element fomnat or element profile or 
meta-element profile or scalable template. This scalable template manager 
offers different alternatives for further managing these entities.: 

20 This can be illustrated with the user interface described with the FIG 6A, 

showing the Scalable Template Manager Dialog Box 600, as displayed on the 
display device 106. Within this Scalable Template Manager Dialog Box 600, 
the user can visualise already defined objects (element formats, 
meta-element fomnats, element profiles, meta-element profiles and scalable 

25 templates) in the "list boxes" 613, 614 and 602 where are respectively 

specified the names of the objects, the types of the objects and their last date 
of update. If a large number of objects have been defined, then the user can 
navigate among them by clicking with the pointing. device 105 either upwards 
on downwards on the scrollbar 603, so that the objects shown within the list 

30 boxes 613, 614 and 602 move back and forth between the top object and the 
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bottom object. In a preferred embodiment of the present invention, the 
objects have been sorted by date of last update, but any other sorting 
schema could be also used without departing from the spirit of the invention. 
Several actions may then be taken by the user. 

The user can use the pointing device 105 to click on a check box on the left 
side of the Scalable Template Manager Dialog Box 600 like the check box 
612, in order to either select or deselect the object whose name Is displayed 
within the list box 613 just on the right of the clicked check box. One or 
multiple objects can be selected or deselected. List scrolling is of course 
reflected on the check boxes. 

Once a selection is performed, the user can use the pointing device 105 to 
click on the "De/efe" push-button 607, if he/she intends to remove all the 
selected objects from the list boxes 613, 614 and 602. If there is no other 
object (either scalable template or scalable template instance) refening to at 
least one of these objects, then they are immediately deleted, so that they do 
no longer appear on the list boxes 613, 614 and 602. Reversely if there exists 
at least one other scalable template or scalable template instance refemng to 
at least one of the selected objects, then a conventional dialog box is 
displayed on the display device 106 to first alert the user about this situation 
and second to invite him to either cancel the deletion operation or to confinn 
it. if the user decision is to cancel the operation, then no action is taken, 
othenA/ise the selected objects are immediately deleted, so that they do no 
longer appear on the list boxes 61 3, 61 4 and 602. 

Altematively the user can use the pointing device 105 to click on the "Edit 
push-button 611 if he/she wants to edit the selected object which is assumed 
to be unique. 

If no object or multiple objects have been previously selected, as shown 
within the Scalable Template Manager Dialog Box 600 by the presence of no 
or multiple check marks (visible or not) within the check boxes located on the 
left side, like the check box 612, then a waming message is displayed on the 
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display device 106 to the user through conventional means such as pop-up 
windows, istatus bar messages, or any other similar conventional means 
which can be used instead without departing from the spirit of the invention. 
Reversely if a single object was previously selected, as shown by the 
presence of a single check mark (visible or not) within a check box located on 
the left side, like the check box 612, then the Scalable Template Manager 
Dialog Box 600 is first closed and aftenA^ards the nature of this single selected 
object is taken into account to determine the new dialog box to be opened. 
If the selected object was an element fomriat or a meta-element fomiat, then 
\\ie Element Format Editor command is issued, so that the Element Format 
Editor method takes control by first displaying on the display device 106 the 
Element Format Editor Dialog Box 621, as illustrated in FIG 68. The following 
steps of this scenario case are detailed in a subsequent section.. 
If the selected object was an element profile or a meta-element profile, then 
the Element Profile Editor command is issued, so that the Element Profile 
Ed/for method takes control by first displaying on the display device 106 the 
Element Profile Editor Dialog Box 641 , as illustrated in FIG 6C. The following 
steps of this scenario case are detailed in a subsequent section. 
If the selected object was a scalable template, then the Scalable Template 
Editor command is issued, so that the Scalable Template Editor method 
takes control by first displaying on the display device 106 the Scalable 
Template Editor Dialog Box 661, as illustrated in FIG 6D. The following steps 
of this scenario case are detailed in a subsequent section. 

Altematively the user can use the pointing device 105 to click on the 
""InstanciateT push-button 604 if he/she wants to generate a scalable template 
instance which abides by the selected object which is assumed to be unique 
and to be a scalable template. 

If no object or multiple objects have been previously selected, as shown 
within the Scalable Template Manager Dialog Box 600 by the presence of no 
or multiple check marks (visible or not) within the check boxes located on the 
left side, like the check box 612, then a warning message is displayed on the 
display device 106 to the user through conventional means such as pop-up 
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windows, status bar messages, or any other similar conventional means 
which can be used, instead without departing from the spirit of the invention. 
Reversely if a single object was previously selected, as shown by the 
presence of a single check mark (visible or not) within a check box located on 
the left side, like the check box 612, then the method checks if this object is a 
scalable template. 

If it is not the case, then a warning message is displayed on the display 
device 106 to the user through conventional means such as pop-up windows, 
status bar messages, or any other similar conventional means which can be 
used instead without departing from the spirit of the invention. 
Reversely if a single scalable template object was previously selected, then 
the Scalable Template Manager Dialog Box 600 is first closed and aftenA/ards 
the Scalable Template Instanciator command is issued, so that the 
Scalable Template Instanciator method takes control by first displaying on 
the display device 106 the Scalable Template Instanciator Dialog Box 1300, 
as illustrated in FIG 13 A. The following steps of this scenario case are 
detailed in a subsequent section. 

Altematively the user can use the pointing device 105 to click on the "Eyporf! . 
push-button 606 if he/she wants to export a non-empty set of objects from the 
cunrent spreadsheet file to another spreadsheet file. 
If no object has been previously selected, as shown within the Scalable 
Template Manager Dialog Box 600 by the absence of any check mark (visible 
or not) within the check boxes located on the left side, like the check box 612, 
then a warning message is displayed on the display device 106 to the user 
through conventional means such as pop-up windows, status bar messages, 
or any other similar conventional means which can be used instead without 
departing from the spirit of the invention. 

Reversely if one or multiple objects were previously selected, as shown by the 
presence of at least one check mark (visible or not) within a check box 
located on the left side, like the check box 612, then the Scalable Template 
Manager Dialog Box 600 is first closed and aftenA^ards the Scalable 
Template Export Manager command is issued, so that the Scalable 
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Template Export Manager method takes control by first displaying on the 
display device 106 the Scalable Template Export Manager Dialog Box 2600, 
as illustrated in FIG 26A. The following steps of this scenario case are 
detailed in a subsequent section. 

Alternatively the user can use the pointing device 105 to click on the Import 
push-button 605 if he/she wants to import one or several objects from another 
spreadsheet file to the cun^ent spreadsheet file. The Scalable Template 
Manager Dialog Box 600 is first closed and aftenA/ards the Scalable 
Template Import Manager command is issued,, so that the Scalable 
Template Import Manager method takes controf by first displaying on the 
display device 106 the Scalable Template Import Manager Dialog Box 2620,. 
as illustrated in FIG 26B. The following steps of this scenario case are 
detailed in a subsequent section. 

Alternatively the user can use the pointing device. 105 to click on one of the 
three option-buttons on the bottom left side of the Scalable Template 
Manager Dialog Box 600, like the ''Profiler option-button 609, if he/she wants 
to specify which type of new object may be created aftenwards. As three 
option-buttons are available on the Scalable Template Manager Dialog Box 
600, the user has the choice to specify either a fomiat, or a profile or a 
scalable template as the type of the new object to be created aften/vards. 

Alternatively the user can use the pointing device 105 to click on the 
check-box 608 entitled "From cun'ent selectlori\ if he/she wants to specify if 
the next object to be created aftenvardsi will be derived 6r not from .the /ange 
of cells currently selected In the spreadsheet file. 

Alternatively the user can use the pointing device 105 to click on the ''Create 
NeW' push-button 610 if he/she wants to create a new object whose type has 
been previously specified thanks to the three option-buttons like 

• the "Profile'' option-button 609, or 

• the "Format option-button 61 7, or 
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• the " Templatd" option-button 61 6. 

If none of these three option-buttons shows a previous user choice, as shown 
within the Scalable Template Manager Dialog Box 600 by the absence of a 
point within one of these three option-buttons 609, 616 and 617, then a 
S warning message is displayed on the display device 106 to the user through 

conventional means such as pop-up windows, status bar messages, or any 
other similar conventional, means which can be used instead without 
departing from the spirit of the invention; 

Reversely if one of these three option-buttons 609, 616 and 617 shows a 
10 previous user choice, then the Scalable Template Manager Dialog Box 600 is 

first closed and aftenwards .the single selected option-button is taken into 

account to determine the new dialog box to be opened. 

If the "Formaf option-button 617 shows a selection, then the Element 

Format Editor command is issued, so that the Element Format Editor 
15 method takes control by first displaying on the display device 106 the Element 

Format Editor Dialog Box 621, as illustrated in FIG 68. The following steps of 

this scenario case are detailed in a subsequent section. 

If the "Profile option-button 609 shows a selection, then the Element Profile 

Editor command is issued, so that the Element Profile Editor method takes 
20 control by first displaying on the display device 106 the Element Profile Editor 

Dialog Box 641, as illustrated in FIG 6C. The following steps of this scenario 

case are detailed in a subsequent section. 

if the "Template option-button 616 shows a selection, then the Scalable 
Template Editor command is issued, so that the Scalable Template Editor 

25 method takes control by first displaying on the display device 106 the 

Scalable Template Editor Dialog Box 661, as illustrated in FIG 6D. The 
following steps of this scenario case are detailed in a subsequent section. 

Finally the user can use the pointing device 1Q5 to click on the "Done^' 
30 push-button 601 or on the closing-window push-button 615 if he/she wants to 

quit the Scalable template Manager method. The resulting effect is to close 
the Scalable Template Manager Dialog Box 600 on the display device 106. 



62 



wo 03/014987 



PCT/EP02/09483 



• b. Element Format Editor 

According to the previous scenario illustrating the Scalable Template 
5 Manager method, the spreadsheet user may then invoke an original specific 

command called ""Element Format Editof thanks to conventional means 
available in spreadsheet environment, such as but not limited to the pointing 
device 105 or the keyboard 104, in order 

• to either create a new element format; or 
10 • to create a new meta-element format; or 

• to update an existing element fomiat; or 

• to update an existing meta-elenient fomnat. 

This can be illustrated with the user interface described with the FIG 6B, 
showing the Element Format Editor Dialog Box 621, as displayed on the 

IS display device 106 within the GUI wiridow 620 of the electronic spreadsheet 

office application. When the Element Fonmat Editor Dialog Box 621 is 
displayed on the display device 106, the current sheet becomes a dedicated 
sheet entitled Editor Spaed' 635 in a preferred embodiment of the present 
invention. Within the ""Editor Spaed* 635 sheet, the element or meta-element 

20 fomriat to be edited appears as a range of cells 634 in the tpp left angle of the 

window 620, with the top left cell at address 82. As the ialement or 
meta-element format corresponds to a regular range of cells 634 within a 
sheet, the conventional tools available in electronic spreadsheet 
environments can be used to update It, This is illustrated for instance with the 

25 Range Properties Dialog Box 633 which is used here to specify that the 

second cell of the element format has an horizontal alignment set to center, 
has a vertical alignment set to bottom, without text alignnient across columns, 
without text wrapping in cells and finally with a natural orientation. Any other 
conventional format attribute could in turn be specified with conventional 

30 means. 

When the Element Fonmat Editor Dialog Box 621 is displayed on the display 
device 1 06, it contains some pieces of information. 
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First the nature of the edited object is shown by a pair of option-buttons 630 
which specifies if it is either an element fonnat or a meta-element fomiat. The 
spreadsheet user can click with the pointing device 105 on one of these two 
option-buttons 630 to swap between an element fomiat definition and a 
meta-element fomnat definition. 

Second the number of cells within the edited object is specified in the text-box 
626. When a new element fomiat or meta-element format is created from the 
currently selected range of cells (the spreadsheet user having previously 
clicked with the pointing device 105 on the check box 608 to put a check 
mark on it, on the option-button 617 to put a point on it and on the 
push-button 610, all contained within the Scalable Template Manager Dialog 
Box 600 as illustrated by FIG 6A), the value shown by the text box 626 
corresponds to the numbers of cells found in the currently selected range of 
cells. When a new element fonnat or meta-element fomiat is created 
regardless of the currently selected range of cells (the spreadsheet user 
having previously clicked with the pointing device 105 on the check box 608 
to clear it, on the option-button 617 to put a point on it and on the push-button 
610, all contained within the Scalable Template Manager Dialog Box 600), 
the value shown by the text box 626 corresponds to a default value set to 8 in 
a preferred embodiment of the present invention. When an existing element 
fonmat or meta-element fonmat is edited, the value shown by the text box 626 
con-esponds to the number of cells previously defined for this object. In all 
cases, the spreadsheet user can change the value shown in the text box 626 
by clicking with the pointing device 105 on the spin-button 627, either on the 
ascending or on the descending side, so that the value can get increased or 
decreased (within predefined boundaries). 

Third the name of the edited element format or meta-element fomiat is 
displayed on the label box 624. When an existing element format or 
meta-element fomiat is edited, the name shown by the label box 624 
corresponds to the name previously assigned to this object. When a new 
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element format or meta-element fomiat is created, then the name displayed 
on the label box 624 con-esponds to a default value which, in a preferred 
embodiment of the present invention,.takes the fomi "New XX" where XX is a 
counter ensuring the uniqueness of the assigned name. 

.5 • 

The Element Fomnat Editor Dialog Box 621 contains several graphical objects 
which allow the spreadsheet user to take some actions. 

First the spreadsheet user can assign a new name to the currently edited . 
element forniat or meta-element fonmat. For this purpose he/she will first use 

10 conventional means such as the keyboard 104 to specify within the text box 

625 the new name to be given to the edited element or meta-element format. 
Then he/she will use the pointing device 105 to click on the "Sav^e >4s" 
push-button 631. If the specified name entered within the text box 625 was 
already assigned to an existing object or is not a valid name, then a waniirig 

15 . . message is displayed on the display device 106 to the user through 
conventional means such as pop-up windows, status bar messages., or any 
other similar conventional means which can be used instead without 
departing from the spirit of the. invention. This warning message inforriis the 
spreadsheet user about this situation and then prompts him for 

20 acknowledgement. Then the text box 625 is cleared without further action. If 

the specified name entered within the text box 625 was not yet assigned to ah 
existing object and was a valid name, then the text box 625 is cleared and the 
edited object is saved on the spreadsheet file under the new name which is in 
turn displayed within the label box 624. 

• '25 . 

Second the spreadsheet user can clear the current element or meta-element 
format definition by clicking with the pointing device 105 on the "Cleat^ 
push-button 629. The resulting effect is to assign to the edited object shown 
by the range 634 all the default attributes currently defined within the opened 
30 spreadsheet file (these attributes being for instance the ones set by default 

when a new sheet is created within the electronic spreadsheet file). 
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Third the spreadsheet user can save on the spreadsheet file the current 
definition of the edited object by clicicing with the pointing device 105 on the 
"Sav^ push-button 632. This event results in checking if the updated element 
of meta-element format is already referenced by an existing scalable 
template. If it is not the case, then the updated definition of the element or 
meta-element fomiat, as described by the illustrative range of cells .634, is 
saved on the spreadsheet file. If it is the case, then a warning message is 
displayed on the display device 106 to the user through conventional means 
such as pop-up windows, status bar messages, or any other similar 
conventional means which can be used instead without departing from the 
spirit of the invention. This warning message infomas the spreadsheet user 
about this situation and then prompts him for either cancelling the operation 
or for pursuing it. In the first case the updated element or meta-element 
format definition, as described by the illustrative range of cells 634, is not 
saved while it is saved on the spreadsheet file in the second case. 

Fourth the spreadsheet user can apply any updated element or meta-element. 
fomiat definition onto any existing scalable template instance abiding by a 
scalable template which refers to the updated format: For this purpose he/she 
use the pointing device 105 to click on the ""Save & Refrestf push-button 628. 
The result effect is first that the element or meta-element format definitiori 
gets saved on the spreadsheet file and then that every existing scalable 
template instance which abides by any scalable template which refers to the 
updated element or meta-element format will be in turn updated to reflect the 
element or meta-element format definition change. 

Finally the user can use the pointing device 105 to click on the Doner 
push-button 623 or on the closing-window push-button 622 |f he/she wants to 
quit the Element Format Editor method. The resulting effect is to close the 
Efement Fonnat Editor Dialog Box 621 on the display device 106 and to 
revert to the sheet which was active when the Element Format Editor 
command was first invoked. 
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• c. Element Profile Editor 

According to the previous scenario illustrating the Scalable Template 
Manager method, the spreadsheet user may then invoke an original specific 
command called ""Element Profile Editof thanl<s to conventional means 
available in spreadsheet environment, such as but not limited to the pointing 
device 105 or the i<eyboard 104, in order to either , create a new element 
profile or to create a new meta-element profile . or to update an existing 
element profile or to update an existing meta-element profile. 

This can be illustrated with the user interface described with the FIG 6C, 
showing the Element Profile Editor Dialog Box 641 , as displayed on the 
display device 106 within the GUI window 640 of the electronic spreadsheet 
office application. When the Element Profile Editor Dialog Box 641 is 
displayed on the display device 106, the current sheet becoriies a dedicated 
sheet entitled ''Editor Spaed' 655 in a prefen-ed embodiment of the present 
invention. Within the ''Editor Spaed* 655 sheet, the element or meta-element 
profile to bis edited appears as a range of cells 654 in the top left angle, with 
the top left cell at address B2. As the elerhent or meta-element profile 
corresponds to a regular range of cells 654 within a sheet, the conventional 
tools available in electronic spreadsheet environments can be used to update 
it. This will typically consist in updating the content of any cell belonging to the 
edited elernent profile or meta-element profile. As far as the "IN" or "OUT" 
nature of each cell is concerned, this infomnation is recorded in a preferred 
embodiment of the present invention by the cell protection mode attribute: a 
cell specified as not protected from changes corresponds to an "IN" cell 
whereas a cell specified as protected from changes corresponds to an "OUT" 
cell. This is illustrated for instance with the Range Properties Dialog Box 653 
which is used here to specify that the second cell of the element profile is 
protected from cell contents, meaning that it is. considered as an "OUT" cell. 
Any other conventional cell attribute could be used instead of the cell 
protection mode attribute without departing from the spirit of the present 
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invention. 

When the Element Profile Editor Dialog Box 641 is displayed on the display 
device 106, it contains some pieces of infomiation. 

5 First the nature of the edited object is shown by a pair of option-buttons 650 

which specifies if it is either an element profile or a meta^element profile. The 
spreadsheet user can click with the pointing device 105 on one of these two 
option-buttons 650 to swap between an element profile definition and a 
meta-element profile- definition. 

10 

Second the number of cells within the edited object is specified in the text-box 
646. When a new element profile or meta-element profile is created from the 
currently selected range of cells (the spreadsheet user having previously 
clicked with the pointing device 105 on the check box. 608 to put a check 

15 mark on it, on the option-button 609 to put a point on it and on the 

push-button 610, all contained within the Scalable Template Manager Dialog . 
Box 600, as illustrated by FIG 6A), the value shown by the text box 646 
conresponds to the numbers of cells found in the currently selected range of 
cells. When a new element profile or meta-element profile is created 

20 regardless of the cunrently selected range of cells (the spreadsheet user 

having previously clicked with the pointing device 105 on the check box 608 
to clear it, on the option-button 609 to put a point on it and oh the push-button 
610, all contained within the Scalable Template Manager Dialog Box 600, as 
illustrated by FIG 6A), the value shown by the text box 646 conresponds to a 

25 default value set to 8 in a preferred embodiment of the present invention. 

When an existing element profile or meta-element profile is edited, the value 
shown by the text box 646 corresponds to the number of cells previously 
defined for this object. In all cases, the spreadsheet user can change the 
value shown in the text box 646 by clicking with the pointing device 105 on 

30 the spin-button 647, either on the ascending or on the descending side, so 

that the value can get increased or decreased (within predefined boundaries). 
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Third the name of the edited element profile or meta-element profile is 
displayed on the label box 644. When an existing element profile or 
meta-element profile is edited, the name shown by the label box 644 
corresponds to the name previously assigned to this object. When a new 
3 element profile or meta-element profile is created, then the name displayed 

on the label box 644 corresponds to a default value, which, in a preferred 
embodiment of the present invention, takes the fonm "New XX" where XX is a 
counter ensuring the uniqueness of the assigned name. 

10 The Element Profile Editor Dialog Box 641 contains several graphical objects 

which allow the spreadsheet user to take some actions. 

First the spreadsheet user can assign a new name to the cun^ently edited 
element profile or meta-element profile. For this purpose he/she will first use 
conventional means such as the keyboard 104 to specify within the text box 

15 645 the new name to be given to the edited element or nieta-element profile. 

Then he/she will use the pointing device 105 to cljck on the "Save 
push-button 651 . If the specified name entered within the text box 645 was 
already assigned to an existing object or was not a valid name, then a 
warning message is displayed on the display device 106 to the user through 

20 conventional means such as pop-up windows, status bar messages, or any 

other similar conventional means which can be used instead without 
departing from the spirit of the invention. This warning message infonms the 
spreadsheet user about this situation and then prompts him for 
acknowledgement. Then the text box 645 is cleared without further action. !f 

25 the specified name entered within the text box 645 was not yet assigned to an 

existing object and was a valid name, then the text box 645 is cleared and the 
edited object is saved on the spreadsheet file under the new name which is in 
turn displayed within the label box 644. 

30 Second the spreadsheet user can clear the current element or meta-element 

profile definition by clicking with the pointing device 105 on the "Ctea/*' 
push-button 649. The resulting effect is to assign to the edited object shown 
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by the range 654 the default content cun^ently defined within the opened 
spreadsheet file (this content being for instance the one set by default when a 
new sheet is created within the electronic spreadsheet file, most often a 'Void" 
content). 

Third the spreadsheet user can save on the spreadsheet file the current 
definition of the edited object by clicking with the pointing device 105 on the 
""Savd' push-button 652. This event results in checking if the updated element 
or meta-element profile is already referenced by an existing scalable 
template. If it. is not the case, then the updated definition of the element or 
meta-element profile is saved on the spreadsheet file. If it is the case, then a 
waming message is displayed on the display device 106 to the user through 
conventional means such as pop-up windows, status bar messages, or any 
other similar conventional means which can be used instead without 
departing from the spirit of the invention. This waming message informs the 
spreadsheet user about this situation and then prompts him for either 
cancelling the operation or for pursuing it. In the first case the updated 
element or meta-element profile definition is not saved while it is saved: on the 
spreadsheet file in the second case. 

Fourth the spreadsheet user can apply any updated element or meta-element 
profile definition onto any existing scalable template instance abiding by a 
scalable template which refers to the updated profile. For this purpose he/she 
use the pointing device 105 to click on the "Save & Refrestf push-button 648. 
The result effect is first that the element or meta-element profile definition 
gets saved on the. spreadsheet file and then that every, existing scalable 
template instance which abides by any scalable template which refers to the 
updated element or meta-element profile will be. in turn updated to reflect the 
element or meta-element profile definition change. 

Finally the user can use the pointing device 105 to click on the "Done" 
push-button 643 or on the closing-window push-button 642 if he/she wants to 
quit the Element Profile Editor method. The resulting effect is to close the 
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Element Profile Editor Dialog Box 641 on the display device 106 and to revert 
to the sheet which was active when the Element Profile Editor command 
was first invoked. 

d. Scalable Template Editor 

According to the previous scenario illustrating the Scalable Template 
Manager method, the spreadsheet user may then invoice an original specific 
command called ""Scalable Template Editof thanks to conventional means 
available in spreadsheet environment, such as but not limited to the pointing 
device 105 or the keyboard 104, in order to either create a new scalable 
templiate or to update an existing scalable template, 

This can be illustrated with the user interiface described with the FIG 6D, 
showing the Scalable Template Editor Dialog Box 661 , as displayed on the 
display device 106 within the GUI window. 660 of the electronic spreadsheet 
office application. When the Scalable Template Editor Dialog Box 661 is 
displayed on the display device 106, the current sheet becomes a dedicated 
sheet entitled ""Editor Spacer 675 in a preferred embodiment of the present 
invention. Within the "" Editor Spacer 675 sheet, the scalable template to be 
edited appears as a range of cells 674 in the top liaft angle, with the top left 
cell at address B2. Although the edited scalable, template corresponds to a 
regular range of cells .674 within a sheet, conventional tools available in 
electronic spreadsheet environments cannot be used to update this range of 
cells 674. The spreadsheet user will only be able! to navigate within the range 
of cells 674 illustrating the scalable template, and to either insert or delete 
rows within the range of cells 674 illustrating the scalable template, by using 
dedicated means which are part of the Scalable Template Editor Dialog Box 
661. Row insertion or deletion in the "Editor Spacer sheet 675 will be 
disabled. Moreover the "Editor Spaed" sheet 675 is write-protected to prevent 
the user to inadvertently modify the settings of the elements or 
meta-elements defined as part of the scalable template Illustrated by the 
range of cells 674. 
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When the Scalable Template Editor Dialog Box 661 is displayed on the 
display device 106, it contains some pieces of infomiation which either relate 
to the whole scalable template, as illustrated by the range of cells 674, or 
which relate to the element or meta-element pointed by the cell currently 
selected within this same range of cells 674.- 

First the fornnat of the element or meta-element pointed by the cell currently 
selected is shown by the Format combo box 671. By clicking with the 
pointing device 105 on the anrow located on the right side of this "Formaf 
combo box 671, the spreadsheet user can display and navigate within the list 
of defined fomiats, then select a format of his/her choice and see the 
resulting visible effect on the row where is located the currently selected cell 
within the range of cells 674. Similarly the profile of the element or 
meta-element pointed by the cell currently selected is shown by . the "Profile 
combo box 670. By clicking with the pointing device 105 on the arrow located 
on the right side of this "Profile!* combo box 670, the spreadsheet user can 
display and navigate within the list of defined profiles, then seject a profile of 
his/her choice and see the resulting visible effect on the row where is located 
the currently selected cell within the range of cells 674. Reversely, if the 
spreadsheet user changes the selected row within the range .of cells 674, by 
clicking with the pointing device 105 on the ''Uff push-button 679, or on the 
"Dowrf push-button 680, then the names displayed within the combo boxes 
671 and 670 are updated to respectively specify the name of the fomiat and 
of the profile of the element or meta-element corresponding to the new 
selected row. If the spreadsheet user wishes to insert a new meta-element 
either in the header or in the footer part of the scalable template, he/she has 
just to click with the pointing device 105 on the ''Adcf push-button 677 to 
insert a new row within the range of cells 674, at the desired place above the 
last position of the currently selected cell. Then the range of cells 674 is 
updated with a new row being displayed on the window 660. Then the 
Scalable Template Editor Dialog Box 661 Is updated by showing within the 
respective combo boxes 671 and 670 the names of the format and profile 
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assigned by default to the introduced meta-element. If the spreadsheet user 
wishes to remove a meta-element either from the header part or from the 
footer part of the scalable template, he/she has just to click with the pointing 
device 105 on the ''Deleter push-button 678 to remove {he corresponding row 
within the range of cells 674, at the desired place. Then the currently selected 
cell within the range of cells 674 becomes the left cell belonging to the row 
representing the unique element defined within the scalable template, and the 
Scalable Template Editor Dialog Box 661 is updated by showing within the 
respective combo boxes 671 and 670 the names of the fomriat and profile of 
the unique element defined within the scalable template.. . 

Second the minimum number of elements allowed within a scalable template 
instance abiding by the edited scalable template is specified in the "MIN' 
text-box 666. Similarly the maximum number of elements allowed within a 
scalable template instance abiding by the edited scalable template is 
specified in the "MAX" text-box 669. When a new scalable template is created 
(the spreadsheet user having previously clicked with the pointirig device 105 
on the option-button 616 to put a point on it and on the push-button 610, all 
contained within the Scalable Template Mainager Dialog Box 600, as 
. illustrated by FIG 6A), the value shown by the "M/AT text box 666 corresponds 
to a default value set to 1 in a preferred embodiment of the present invention, 
and the value shown by the "MA^ text box 669 corresponds to a default 
value set to 255 in a preferred embodiment of the present invention. When an 
existing scalable template is edited, the values shown by the text boxes 666 
and 669 correspond respectively to the minimum and maximum number of 
elements allowed in any scalable template instance abiding by the cun^ently 
edited scalable template, as previously defined by the spreadsheet user. In all 
cases, the spreadsheet user can change the values shown in the text box 
"/WW 666 or in the text box ''MAX* 669 by clicking with the pointing device 
105 respectively on the spin-button 667 or on the spin-button 668, either on 
the ascending or on the . descending side, so that the values can get 
increased or decreased (within predefined boundaries), while ensuring that 
the value specified in the "MIN' text box 666 remains less than or equal to the 
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value specified in the "MAA" text box 669. Should any existing scalable 
template instance abiding by the updated scalable template have a number of 
elements falling outside the new '"MlhT-^MAX* interval, then this instance will 
not be impacted by the scalable template update, but any future addition or 
removal of elements will be done according to the new definition of the 
"/W/Ar-"M4X" interval. 

Third the name of the edited scalable template is displayed on the label box 
664. When an existing scalable template is edited, the name shown by the 
label box 664 corresponds to the name previously assigned to this object. 
When a new scalable template is created, then the name displayed on the 
label box 664 corresponds to a default value which, in a preferred 
embodiment of the present invention, takes the fomri "New XX" where XX is a 
counter ensuring the uniqueness of the assigned name. 

The Scalable Template Editor Dialog Box 661 comprises several graphical 
objects which allow the spreadsheet user to take some actions. 

First the spreadsheet user can assign a new name to the currently edited 
scalable template, if this scalable template is currently constituted by element 
fomiats, element profiles, meta-element formats and nieta-element profiles 
having all the same number of fields. Indeed, in this case the "Save 
push-button 672 is enabled, so that any click on it with the pointing device 
105 is recognised as a valid event. The spreadsheet user will first use 
conventional means such as the keyboard 104 to specify within the text box 
665 the new name to be given to the edited scalable template. Then he/she 
will use the pointing device 105 to click on the "Save push-button 672. If 
the specified name entered within the text box 665 was already assigned to 
an existing object or is not a valid name, then a warning message is displayed 
on the display device 106 to the user through conventional means such as 
pop-up windows, status bar messages, or any other similar conventional 
means which can be used instead without departing from the spirit of the 
invention. This warning message infomns the spreadsheet user about this 
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situation and then prompts hentiim for. acknowledgement. Then the text box 
665 is cleared without further action, if the specified name entered within the 
text box 665 was not yet assigned to an existing object and is a valid name, 
then the text box 665 is cleared and the edited scalable template is saved on 
the spreadsheet file under the new name which is in turn displayed within the 
label box 664. 

Second the spreadsheet user can save on the spreadsheet file the current 
definition of the edited scalable template, if this scalable template is currently 
constituted by element fomnats, element profiles, meta-element fonnats and 
meta-element profiles having all the same number of fields. Indeed in this 
case the "Save^' push-button 673 is enabled, so that any click on it with the 
pointing device 105 is recognised as a valid event. This event results in 
checking if the updated scalable template is already referenced by an existing 
scalable template instance. If it is not the case, then the updated definition of 
the scalable template is saved on the spreadsheet file. If it is the case, then a 
warning message is displayed on the display device 106 to the user through 
conventional means such as pop-up windows, status bar messages, or any 
other similar conventional means which can be used instead without 
departing from the spirit of the invention. This waming message infonms the. 
spreadsheet user about this situation and then prompts him for either; 
caricelling the operation or for pursuing it. In the first case the updated 
scalable template definition is not saved while jt is saved on the spreadsheet 
file in the second case. 

Finally the user can use the pointing device 105 to click on the "Done^' 
push-button 663 or on the closing-window push-button 662 if he/she wants to . 
quit the Scalable Template Editor method. The resulting effect is to close the 
Scalable Template Editor Dialog Box 661 on the display device 106 and to 
revert to the sheet which was active when the Element Profile Editor 
command was first invoked. 
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e. Scalable Template Instanciator 

According to the previous scenario illustrating tlie Scalable Template 
Manager method, the spreadsheet user may then invoke an original specific 
command called ""Scalable Template Instanclatof thanks to conventional 
means available in spreadsheet environment, such as but not limited to the 
pointing device 105 or the keyboard 104, in order to create a scalable 
template instance abiding by a selected scalable template and located 
according to the currently selected cell. 

This can be illustrated with the user interface described with the FIG 13 A, 
showing the Scalable Template Instanciator Dialog Box 1300, as displayed on 
the display device 106. When the Scalable Template Instanciator Dialog Box 
1300 is displayed on the display device 106, the current sheet remains still 
active, so that the spreadsheet user can visualise the data present on It. The 
Scalable Template Instanciator Dialog Box 1300 contains some pieces of 
information which relate to the instanciation operation. 

First the name of the scalable template that abides by the scalable template 
instance to be created, is displayed in a label box 1315. 

Second the number of elements to be present at instance creation time is 
shown in a text box 1312. This number takes a default value equal to 8 (eight) 
in a preferred embodiment of the present invention. If the spreadsheet user 
wished to create a scalable template instance with another number of 
elements, then he/she will have to click with the pointing device 105 on the 
upper or lower side of the spin-button 1313 to either increase or decrease the 
number of elements. This number of elements will vary within a range 
delimited by the minimum and maximum number of elements, as specified 
within the definition of the scalable template (fields "/W/n Element #' 725 and 
"Max Element r 726 within a record 721 of the STT table 720 whose "A/ame^ 
field 722 matches the name displayed in the label box 1315) and is displayed, 
after possible update, in the text box 1312. 
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Third the mode of the instanciation is specified by the presence of a blacl< 
point within one of the five option buttons "Overlaf 1309, "Horizontal Insert 
1308, Horizontal Insert by Rang^ 1307, ''Vertical Inserf 1306 and Vertical 
Insert by Rang^ 1305. If the spreadsheet user wishes to change the default 
mode of instanciation which is ""Overiaf or a previously changed mode of 
instanciation, then he/she uses the pointing device 105 to click on one of the 
five option buttons "Overia/ 1309, Horizontal Inserf 1308, Horizontal Insert 
by Rang^ 1307, ''Vertical Insert' 1306 and "Vertical Insert by Rangef' 1305 
which will display alone a black point specifying the new selected mode of 
instanciation. 

Fourth the check box 1314 allows the spreadsheet user to specify if the new 
scalable template instance is considered or not as a ^Criticar instance, if and 
only if the check box 1314 displays a check mark, then the scalable template 
instance will be created as a critical one. By clicking with the pointing device 
105 on this check box 1314, the spreadsheet user can swap between a 
"Criticar. and not ""Criticar instance, which is reflected by the presence or 
absence of a check mark within this same check box 1314, 

Fifth the push-button "Cancer 1302 or the closing-window push-button 1301 
allow to close the Scalable Template Instanciation Dialog Box 1300 without 
further action. By clicking with the pointing device 105 on one of these, two 
push-buttons 1301 and 1302, the Scalable Template Instanciation Dialog Box 
1300 is closed and the scalable template instanciation operation is aborted. 

Sixth the push-button 'Vreatef' 1303, when first enabled and second clicked 
with the pointing device 105 by the spreadsheet user, is the trigger launching 
the operation of scalable template instanciation. This push-button "CreateT 
1303 is enabled (meaning that the method recognises the click event with the 
pointing device on this push-button '^CreateT 1303) when the instanciation 
operation is possible. The fact that this scalable template instanciation is 
possible or not depends on different factors: the position of the currently 
selected cell within the cun^ent sheet of the electronic spreadsheet, the size of 



77 



wo 03/014987 



PCT/EP02/09483 



the scalable template to be created, the mode of instanclation, the presence 
of any existing critical scalable template instance which would be conxipted 
due to the new instance creation. The possibility to create or not a new 
scalable template instance with the size specified in the text box 1312, 
abiding by a scalable template whose name is specified by the label box 
1315, with the top left comer located on the cunrently selected cell, and 
according to the mode of instanciation specified by one of the five option 
buttons 1305, 1306, 1307, 1308 and 1309, is reflected by several label boxes, 
taking the values *Ves" or "no", which are part of the Scalable Template 
Instanciation Dialog Box 1300: the label box 1310 which reflects if the new 
scalable template instance is or not too high, the label box 1311 which 
reflects if the new scalable template instance is or not too wide, and the set of 
15 label boxes 1304 which are organised as a matrix of 5 rows by 3 columns 
and which reflect for each possible mode of instanciation (one per row) if the 
creation of the new scalable template instance may lead to corrupt any 
existing critical scalable template instance (first column), or may lead to 
corrupt any other existing scalable template instance or may lead to loose any 
existing data present in one or several spreadsheet cells. As soon as the 
value "yes" is taken by the label box 1310, or by the label box 1311, or by the 
1304 label box located at the intersection of the leftmost column and of the 
row corresponding to the selected mode of instanciation, then the instance 
creation is considered as impossible, so that the "Creafe" push-button 1303 
get disabled. Reversely, if the value ''no" is displayed in these three label 
boxes, then the instanciation operation is possible, so that the "Create. 
push-button 1303 get enabled. When clicked with the pointing device 105 by 
the spreadsheet user, the instanciation operation is perfomned, and then the. 
Scalable Template Instanciation Dialog Box 1300 is closed. 

The way the creation of a new scalable template instance may corrupt an 
existing scalable template instance or may lead.to loose any data present in a 
cell is illustrated for each mode of instanciation by the FIG 13B, 13C, 13D, 
13E, 13F and13G. 
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Referring first to the FIG 13B. one can see an illustration of the current sheet 
1320 before the instanciatlon operation is triggered. This sheet is first 
characterised by its number of columns STLsheeLwidth 1321 and by its 
number of rows STLsheetJheight 1322. Within this cunrent sheet, the 

S currently selected cell 1327 is also characterised by its row offset number 

STLoffsetJheight 1324 and by its column offset number STLoffset^width 
1323. The new scalable template instance to be created will correspond to a 
range of cells STLrange 1328 which is itself characterised by a number of 
rows STIJheight 1326 and by a number of columns STLwidth 1325. Four 

10 other ranges of cells can now be identified within the current sheet 1320: the 

range of cells STLhorizontaUlushed^range 1330 which is located on the 
same rows than the range of cells STLrange 1328, but in \he STLwidth 1325 
rightmost columns; the range of cells STLverticaLflushed_range 1332 which 
is located on the same columns than the range of cells STLrange 1328, but 

15 in the STLheight 1326 bottom rows; the range of cells . 

STLhorizontaLkepLrange 1329 located between the ranges of cells. 
STLrange 1328 and STLhorizontaLflushed_range 1330; and the range of 
cells STLverticaLkepLrange 1331 located between the ranges of cells - 
STLrange 1328 and STLyerticaLflushed_range 1332. Finally the FIG 13B 

20 also shows 6 existing scalable template instances: the ranges of cells 

STLhorizdntaLcuUnstance 1333, STLverticaLcuUnstance 1334, 
STLhorizontaLshearedJnstance 1 335, STLverticaLshearedJnstance 
1336, STLverticaLflushedJnstance 1337, STLhorizontaLflushedJnstance 
1338. 

25 . . 

Referring now to FIG 13C, the "overuy" mode is illustrated as the. new 
instance is created as the range of cells 1341 within the updated cuirent 
sheet 1340. The instanciatlon operation consists here in replacing the fomier 
range of cells STLrange 1328 by the new instance. The previously existing 
30 scalable template instance STLverticaLcuUnstance 1334 is cormpted as its 

top right comer has been ovenwritten by the newly created instance: only the 
shape 1342 has been left untouched by the instanciatlon operation. If this 
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previously existing scalable template instance STLverticaLcutJnstance 1334 
was a critical one, then the instanciation operation would have been 
considered as impossible (push-button "Create 1303 being disabled). If this 
previously existing scalable template instance STLverticaLcutJnstance 1334 
S was not a critical one, then the instanciation operation would have been 

considered as possible (push-button "Creafe^' 1303 being enabled), but the 
range of cells STLverticaLcutJnstance 1334 would no longer be considered 
as an instance. 

10 Referring now to. FIG 13D, the "horizontal insert" mode is illustrated as the 

new instance is created as the range of cells 1351 within the updated current 
sheet 1350. With this mode, a number of rows 1356 equal to STI^tieight 1326 
is first inserted at the position occupied by the qurrently selected ceil 1327, 
then the new scalable template instance 1351 is created with the top left cell 

15 located on the currently selected cell 1327. The insertion of the new . rows 

may have some impact on existing instances. First any instance like the 
STI_horizontal_cutJnstance 1333 (which crossed the row of the currently 
selected cell 1327) is cut into two pieces: the top piece. 1352 which , was 
located above the row of the currently selected ceil 1327 and the bottom 

20 piece 1353 which was located below the row of the cun-ently selected cell 

1327. Second any instance like the STI_verticalJlusheclJnstance 1337 
(which was overlapping the last STIJieiglit 1326 rows) is partially or totally 
flushed away from the current sheet, so that only a sub-set of it (possibly 
void) 1354 remains within the limits of the current sheet 1350. Third any data 

25 previously located within the last STI_lieigfit 1326 rows is now pushed away 

from the current sheet 1350 in an area 1355. As previously explained, if. one 
of the corrupted existing instance is a critical instance, then the instanciation 
operation would be considered as impossible, so that the "Create' 
push-button 1303 remains disabled. OthenArise the instanciation operation is 

30 perfomned, and any existing impacted scalable template instance will no 

longer be considered as a scalable template instance. 

Referring now to FIG 13E, the "vertical iNSEmr" mode is illustrated as the new 
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instance is created as the range of cells 1361 within the updated cun-ent 
sheet 1360. With this mode, a number of columns 1365 equal to STLwidth 
1325 is first inserted at the position occupied by the cun^ntly selected cell 
1327, then the new scalable template instance 136t is created with the top 
left cell located on the cun^ently selected cell 1327. The insertion of the new 
columns may have some inripact on existing instances. First any instance like 
the STLverticaLcuUnstance 1334 (which crossed the column of the 
cun-ently selected cell 1327) is cut into two pieces: the left piece 1362 which 
was located on the left of the column of the currently selected cell 1327 and 
the right piece 1363 which was located on the right of the column of the 
currently selected cell .1327. Second any instance like the 
STLhorizohtaUlushedJnstance 1338 (which was overiapping the last 
STLwidth.^325 columns) is partially or totally flushed away from the current 
sheet, so that only a sub-set of it (possibly void) 1364 remains within the limits 
of the current sheet 1360: Third any data previously located within the 
rightmost STLwidth 1325 .columns is now pushed away from the current 
sheet 1360 in an area 1366. As previously explained, if one of the comjpted 
existing instance is a critical instance, then the instanciation operation would 
be considered as impossible, so that the ""Greater push-button 1303 remains 
disabled. Othenwise the instanciation operation is perfomied, and any existing 
inripacted scalable template , instance will no longer be considered as a 
scalable template instance. 

Referring now to FIG 13F, the "horizontal insert by range" mode is illustrated 
as the new instance is created as the range of cells 1371 within the updated 
current sheet 1370. With this mode, the two ranges of cells STLrange 1328 
and STLverticaLkept_range 1331 are moved down by a number of rows 
equal to STLheight ^326, so that space is left available for the new instance 
1371, and so that the bottom range of cells STLverticaUlushed_range 1332 
is moved away from the limits of the current sheet 1370 in an area 1376. The 
range move may have some impact on existing instances. First any instance 
like the STLverticaLcutJnstance 1334 and the 
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STLverticaLshearedJnstance 1336 (which partially overiapped the two 
ranges of cells 1328 and 1331 moved down) are sheared into two pieces: the 
left pieces 1372 and 1375 and the right pieces 1373 and 1374. Second any 
instance which was overlapping the range of cells STLverticalJIushedi^mnge 
1332 is partially or totally flushed away from the cun'ent sheet, so that only a 
sub-set of it (possibly void) remains within the limits of the current sheet 1370. 
Third any data previously located, within the range of cells 
STLvertical_flushed_range 1332 is now pushed away from the current sheet 
1370 in an area 1376. As previously explained, if one of the corrupted 
existing instance Is a critical instance, then the instanciation operation would 
be considered, as impossible, so that the ''Create push-button 1303 remains 
disabled. Otherwise the instanciation operation is performed, and any existing 
impacted scalable template instance will no longer be considered as a 
scalable template instance. 

Referring now to FIG 13G, the "vertical iNSEm' by range" mode is illustrated as 
the new instance is created as the range of cells 1381 within the updated 
cun^ent sheet 1380. With this rnode, the two ranges of ciells STI_range 1328 
and ,STLhorizontal_kept_range 1329 are moved right by a number of 
columns equal to STLwidth 1325, so that space is left available for the new 
instance 1381, and so that the rightmost , range of cells 
STLhorizontaUlushed^range ^330 is moved away from the limits of the 
current sheet 1370 in an area 1388. The range move may have some impact 
on existing instances. First any instance like the STI_horizontal_cut_instance 
1333, the STI_vertical_cutJnstance 1334, and . the 
STLhorizontaLshearedJnstance 1335 (which partially overlapped the two 
ranges of cells 1328 and 1329 moved rights) are sheared into two pieces: the 
top pieces 1383, 1384 and 1387 and the bottom pieces 1382, 1385 and 
1386. Second any instance which was overlapping the range of cells 
STLhorizontal_flushed_range 1330 is partially or totally flushed away from 
the current sheet, so that only a sub-set of it (possibly void) remains within the 
limits of the current sheet 1380. Third any data previously located within the 
range of ceWs STLhorizontaLflushed^range 1330 is now pushed away from 
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the current sheet 1380 in an area 1388. As previously explained, if one of the 
corrupted existing instance is a critical instance, then the instanciation 
operation would be considered as impossible, so that the "Creafe" 
push-button 1303 remains disabled. OthenAfise the instanciation operation is 
S perfonmed, and any existing impacted scalable template instance will no 

longer be considered as a scalable template iristance. 

. • 2. Second Operation : Introduction of New Elements Within a Defined 
Scalable Template Instance 

10 The second operation occurs when the spreadsheet user decides, based on his 
or her own criteria not detailed here, to introduce new elements within a defined 
scalable template instance. In a preferred embodiment of the present invention, 
this operation comprises the following steps: 

• a. The spreadsheet user first selects a range of cell of his/her choice by using 
15 ^ conventional means, such as but not limited to the pointing device 105 or the 

keyboard 104. 

• b. Scalable Template Instance Insertion IManager 

20 Then the spreadsheet user invokes thanks to conventional means available in 
spreadsheet environment, such as (but not limited to) dedicated 
push-buttons, keyboard entry short cuts, menu or sub-menu entries, an 
original specific command called "Scalable Template Instance Insertion 
Managef which enriches the conventional means for inserting cells, or rows 

25 . within a spreadsheet. In a prefen-ed embodiment of the present InvjBhtion, the 
''Scalable Template Instance Insertion Manager" command Is invoked by 
using the same set of means as the ones available in conventional electronic 
spreadsheets for inserting a range of cells within a sheet, such as but not 
limited to clicking with the pointing device 105 on a "Inserf sub-menu entry of 

30 the "Range" menu entry, or keying the "Ctrl +" key on the keyboard 104. 
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When the command is invoked, a test is first perfomied to detemiine If the 
currently selected cell belongs or not to an existing scalable template 
instance. 

if it is the case, then a second test is perfomned to detenmine the relative 
5 position of the cun^ently selected cell within this scalable template instance, 

which will be referred to as the current scalable template instance. 
If the cun^ently selected cell is found within the header part of within the footer 
part of the current scalable template Instance, then the insertion operation will 
certainly corrupt this instance. To this effect a warning message is issued on 

10 the display device 106 through conventional means such as pop-up windows, 

status bar messages, or any other similar conventional means which can be 
used instead without departing from the spirit of the invention. This warning 
message informs the spreadsheet user about this case, and the spreadsheet 
user is then invited through conventional prompting means such as a dialog 

15 box with "Cancer and ''Continue" push-buttons, or through any other similar 

conventional means which can be used instead without departing from the ^ 
spirit of the invention, to either cancel the insertion operation, or to continue it, 
meaning that the current scalable template instance will loose its instance 
nature. 

20 If the spreadsheet user decision is to cancel the insertion operation, then the 

waming and prompting means disappear from the display device 106 and the 
insertion operation is aborted. 

If the spreadsheet user decision is to continue the insertion operation, then 
the current scalable template instance is no longer considered as an 

25 instance, so that the remaining command execution becomes the same as 

the one followed when the result of the Initial test Indicjates that the currently 
selected cell does not belong to a scalable template instance. 
If the cun^ently selected cell is found outside the header part and the footer 
part of the current scalable template instance, but within the body part of the 

30 cun^ent scalable template instance, then the insertion operation is followed by 

displaying on the display device 106 the Scalable Template Insert Manager 
Dialog Box 1600, as illustrated by FIG 16A. 
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If the currently selected cell is found outside a scalable template instance (or 
if it was within the header of footer parts of the current scalable template 
Instance that the spreadsheet user has decided to no longer consider as a 
scalable template instance) and if the insertion operation may lead to corrupt 
an existing scalable template instance, then the insertion operation is 
followed by displaying on the display device 106 the Scalable Template Insert 
Manager Dialog Box 1620, as illustrated by FIG 16B. 
If the cunrently selected cell is found outside a scalable template instance (or 
if it was within the header of footer parts of the current scalable templaite 
instance that the spreadsheet user has decided to no longer consider as a 
scalable template instance) and if the insertion operation cannot corrupt any 
existing scalable template instance, then the conventional means interfacing 
the spreadsheet user for initiating an insertion operation are used. 

The Scalable Template Insert l\/lanager Dialog Box 1600 contains some 
pieces of infomriation which relate to the insertion operation in the case where 
the currently selected cell is within an existing scalable template instance. 

First the name of the scalable template abiding by the current scalable 
template instance is displayed in a label box 1 61 1 . 

Second the number of elements to be inserted is shown in a text box 1608. 
This number takes as initial value the number of rows contained in the 
cun-ently selected range of cells. If the spreadsheet user wishes to insert 
within the current scalable template instance another number of elements, 
then he/she will have to click with the pointing device 105 on the upper or 
lower side of the spin-button 1609 to either increase or decrease the number 
of elements to be inserted. This number of inserted elements will vary within a 
range whose boundaries are delimited by ensuring that the sum of the 
number of already existing elements and of the number of inserted elements 
remains within the minimum and maximum number of elements, as specified 
within the definition of the scalable template (fields "M/n Element W 725 and 
"/Wax Element r 726 within a record 721 of the STT table 720 whose "NameT 
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field 722 matches the name displayed in the label box 1611) and is displayed, 
after possible update, in the text box 1608, whereas the cunentty selected 
range of cells is updated accordingly by containing as many rows as the 
number of inserted elements. 

Third the mode of the insertion is specified by the presence of a black point 
within one of the two option buttons Horizontal Insert 1606 and Horizontal 
Insert by RangeT 1605. If. the spreadsheet user wishes to change the default 
mode of insertion which is "horizontal insert or a previously changed mode 
of insertion, then he/she uses the pointing device 105 to click on one of the 
two option buttons Horizontal Insert 1606 and Horizontal Insert by Rangd' 
1605 which will display alone a black point specifying the new selected mode 
of insertion. 

Fourth the check box 1610 allows the spreadsheet user to visualise and 
possibly to change if the current scalable template instance is considered or 
not as a "Cnf/ca/' instance. If and only if the check box 1610 displays a check 
mark, then the current scalable template instance is a critical one. By clicking 
with the pointing device 105 on this check box 1610, the spreadsheet user 
can swap between a ""Criticar and not "Critioar instance, which is reflected by 
the presence or absence of a check mark within this same check box 1610. 

Fifth the push-button "CanceP 1602 or the closing-wndow push-button 1601 
allow to close the Scalable Template insert Manager Dialog Box 1600 without 
further action. By clicking with the pointing device 105 on one of these two 
push-buttons 1601 and 1602, the Scalable Template Insert Manager Dialog 
Box 1600 is closed and the scalable template insertion operation is aborted. 

Sixth the push-button Insert 1603, when first enabled and second clicked 
with the pointing device 105 by the spreadsheet user, is the trigger launching 
the operation of scalable template insertion. This push-button Insert 1603 is 
enabled (meaning that the method recognises the click event with the 
pointing device on this push-button Insert 1603) when the insertion 
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operation is possible. The fact that this scalable template insertion operation 
Is possible or not depends on different factors: the position of the currently 
selected cell within the cunrent scalable template instance, the size of the 
current scalable template instance, the mode of insertion, the presence of 
S any other existing critical scalable template instance which would be 

corrupted due to the Insertion operation. The possibility to insert or not within 
the current scalable template instance a number of elements specified in the 
text box 1608, at a row position corresponding to the cunrently selected cell, 
and according to the mode of insertion specified by one of the two option 

10. buttons 1605, and 1606, is reflected by several label boxes, taking the values 
'Ves" or "no", which are part of the Scalable Template Insert Manager Dialog 
Box 1600: the label box 1607 which reflects if the cunrent scalable template 
instance would or not be too high after the insertion operation, and the set of 
6 label boxes 1604 which are organised as a matrix of 2 rows by 3 columns 

15 and which reflect for each possible mode of insertion (one per row) if the 

insertion of the number of elements specified by the text box 1608 within the 
current scalable template instance may lead to corrupt any other existing 
critical scalable template instance (first column), or may lead to corrupt any 
other existing not critical scalable template instance or may lead to loose any. 

20 existing data present in one or several spreadsheet cells. As soon as thei 

value 'Ves" is taken by the label box 1607, or by the 1304 label box located at 
the intersection of the leftmost column and of the row corresponding to the 
selected riiode of insertion, then the insertion, operation is considered as 
Impossible, so that the "Inserf push-button 1603 get disabled. Reversely, if 

25 the value "no" is displayed in these label boxes, then the insertion operation is 

possible, so that the "/nserf push-button 1603 get enabled. When clicked 
with the pointing device 105 by the spreadsheet user, the insertion operation 
is pertomied, and then the Scalable Template Insert Manager Dialog Box 
1600 is closed. 

30 The way the insertion of new elements within the current scalable template 

instance may corrupt another existing scalable template instance or may lead 
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to loose any data present in a cell is illustrated for each mode of Insertion by 
the FIG 17A, 17B, and 17C. 

Refemng first to the FIG 17A, one can see an illustration of the cun-ent sheet 
1700 before the insertion operation is triggered. This sheet is first 
characterised by its number of columns STIM_sheet_wiclth 1701 and by its 
number of rows STIM_sheet_height 1702. Within this current sheet, the 
currently selected cell 1707 is also characterised by its row offset number 
STIM_range_offseLheight 1709 and is part of the currently selected range of 
cells STIM_range 1708 which is itself characterised by a number of rows 
STIM_height 1706. The current scalable template instance corresponds to a 
range of cells STIMJnstance_range 1713 which is itself characterised by a 
number of columns STIM_width 1705. The range of cells 
STIMJnstance_range 1713 is also characterized by its. row offset number 
STIM^offset^height 1704 and by its column offset number STIM_offset_width 
1703. Three other ranges of cells can now be identified within the cun-ent 
sheet 1700: 

• the range of cells STIM_row_range 1710 which corresponds to the row 
where is located the curently selected cell 1707, but in the columns 
located on the right of the range of cells STIMJnstance_rangeM^Z\ 

• the range of cells STIM_verticaLflushed_range 1712 which is located on 
the same columns than the range of cells STIMJnstance_range ITiS, but 
in the Sr/yWL/?e/gf/7M 706 bottom rows; and 

• the range of cells STIM^verticaLkepLrange 1711 located between the 
range of cells STIMJnstance^range . 1713 . and 
STIM_verticaLflushed_range 1712, 

Finally FIG 17A also shows 4 existing scalable template instances: the ranges 
of cells 

• STIM_horizontal_cutJnstance 17^4, 

• STIM^verticalJostJnstance 1 71 7, 

• STIM_verticaLshearedJn$tance 1 71 5, 

• STIM^verticaLflushedJnstancB 1 71 6, 
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Referring now to FIG 17B, the "horizontal insert" mode is illustrated by the 
new inserted elements oooBsponding to the range of cells 1721 within the 
updated cun^ent sheet 1720. With this mode, a number of rows equal to 
STlMJheight 1706 is first inserted at the position occupied by the cun^ently 
selected cell 1707, then the new elements 1721 are created within the cunrent 
scalable template instance. The insertion of the new rows may have some 
impact on existing instances. 

First any instance like the STIMJiorjzontaLcutJnstance 1714 (which crossed 
the row STIM_row_range 1710 of the currently selected cell 1707) is cut into 
two pieces: 

• the top piece 1722 which was located above the row STIM_row_range 
1710 of the currently selected cell 1707 and 

• the bottom piece 1723 which was located below the row STIM_row_range 
1710 of the currently selected cell 1707": 

Second any instance like the STIM_verticaUlushedJnstance 1716 (which 
was overlapping the last STlMJheight 1706 rows) or 
STlM_venicalJostJnstance MM (which was included within the last 
STlMJheight 1706 rows) is partially or totally flushed away from the current 
sheet, so that only a sub-set of it (possibly void) 1724 remains within the limits 
of the current sheet 1720, or so that it is totally moved away from the current 
sheet 1720, as an "out-of-sheef* range 1725. Also any data previously 
located within the last STIM_height 1706 rows is now pushed away from the 
current sheet 1720. 

As previously explained, if one of the corrupted existing instance is a critical 
instance, then the insertion operation would be considered as impossible, so 
that the "/nse/f' push-button 1603 remains disabled. Othenwise the insertion 
operation is perfomned, and any existing impacted scalable template instance 
will no longer be considered as a scalable template Instance. 

Referring now to FIG 17C, the "horizontal insert by range" mode is illustrated 
by the new inserted elements corresponding to the range of cells 1731 within 
the updated current sheet 1730. With this mode, the range of cells which 
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occupies the same columns as the range of cells STIMJnstance^range 1713, 
and which occupies the rows below the cun-ently selected cell is moved down 
by a number of rows equal to STIM_height 1706, so that space is left 
available for the new inserted elements 1731, and so that the bottom range of 
5 cells STIM_verticaLflushed_range 1712 is moved away from the limits of the 

current sheet 1730 in an area 1735. The range move may have some impact 
on existing instances. 

First any instance like the STIM_verticaL$hearedJnstance 1715 (which 
partially overlapped the range of cells which occupies the same columns as 
10 the range of cells STIMJnstance^range 1713, and which occupies the rows 

below the currently selected cell) is sheared into two pieces: the left piece 
1733 and the right piece 1732. 

Second any instance like the STIM_verticalJostJnstanQe 1717 previously 
located within the range of cells STIM_verticaUlushed_range 1712 is totally 
15 moved away from the cun^ent sheet 1730 as an out-pf-limit. instance 1734. 

Also any data previously located within the rariige of cells 
STIM_verticaLflushed^range 1712 is now pushed away from the cun-ent 
sheet 1730 in an area 1735. 

As previously explained, if one of the comipted existing instance is a critical 
20 instance, then the insertion operation would be considered as impbssiblei, so 

that the "Inserf push-button 1603 remains disabled. Othenwise the insertion 
operation is performed, and any existing impacted scalable template instance 
will no longer be considered as a scalable template instance. 

The Scalable Template Insert Manager Dialog Box 1620 comprises some 
25 pieces of inforniation which relate to the insertion operation in the case where 

the currently selected cell is outside any existing scalable template instance. 

First a label box 1629 filled with the reserved value "None" indicates that the 
currently selected cell does not belong to any existing scalable template 
instance. 
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Second the mode of the insertion is specified by the presence of a black point 
within one of the four option buttons "Horizontal Insert 1628, "Horizontal 
Insert by RangeT 1627, Vertical Inserf 1626 and Vertical Insert by Rang^ 
1625. If the spreadsheet user v\rishes to change the default nDode of insertion 
which is ""Horizontal insert or a previously changed mode of insertion, then 
he/she uses the pointing device 105 to click on one of the four option buttons 
"Horizontal Insert 1628, "Horizontal Insert by RangeT 1627, Vertical Insert 
1626 and "Vertical Insert. by Rang^' 1625 which will display alone a black 
point specifying the new selected mode of insertion. 

Third the push-button "Cancer 1622 or the closing-window push-button 1621 
allow to close the Scalable Template Insert Manager Dialog Box 1620 without 
further action. By clicking with the pointing device 105 on one of these two 
push-buttons 1621 and 1622, the Scalable Template Insert Manager Dialog.. 
Box 1620 is closed and the insertion operation is aborted. 

Fourth the push-button "Insert" 1623, when first. enabled and second clicked 
with the pointing device 105 by the spreadsheet usfer, is the trigger launching 
the operation of insertion. This push-button "Insert- 1623 is enabled (nieanirig 
that the method recognises the click event with the pointing device on this 
push-button "Insert 1623) when the insertion operation is possible. The fact 
that this insertion operation is possible or not depends on different factors: 
the position of the currently selected cell within the current sheet of the 
electronic spreadsheet, the size of the currently selected range of ceils, the 
mode of insertion, the presence of any existing critical scalable template 
instance which would be corrupted due to the insertion operation. The 
possibility to perfomn or not the insertion according to the mode of insertion 
specified by one of the four option buttons 1625, 1626, 1627, and 1628, is 
reflected by several label boxes, taking the values "yes" or "no", which are part 
of the Scalable Template Insert Manager Dialog Box 1620: the set of 12 label 
boxes 1624 which are organised as a matrix of 4 rows by 3 columns and 
which reflect for each possible mode of insertion (one per row) if the insertion 
operation may lead to comjpt any existing critical scalable template instance 
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(first column), or may lead to corrupt any other existing scalable template 
instance or may lead to loose any existing data present in one or several 
spreadsheet cells. As soon as the value 'Ves'' is taken by the 1624 label box 
located at the intersection of the leftmost column and of the row 
coo'esponding to the selected mode of insertion, then the insertion operation 
is considered as impossible, so that the Insert push-button 1623 get 
disabled. Reversely, if the value "no" is displayed in this label box, then the 
insertion operation is possible, so that the "Insert* push-button 1623 get 
enabled. When clicked with the pointing device 105 by the spreadsheet user, 
the insertion operation is performed, and theri the Scalable Template Insert 
Manager Dialog Box 1 620 is closed; 

The way the insertion operation may corrupt an existing scalable template 
instance or may lead to loose any data present in a cell is illustrated for each 
mode of insertion by the FIG 17D, 17E, 17F, 17G and 17H. 

Referring first to the FIG 17D, one can see an illustration of the cun-ent sheet 
1740 before the insertion operation is triggered. This sheet is first 
characterised by its number of columns STIM^sheet^width 1741 and by its 
number of rows STIM^sheetJheight 1742. Within this cun'ent sheet, the 
cunrently selected cell 1747 is also characterised by its row offset number 
STIM_offset_helght 1744 and by its column offset number STIM^offsetjwidth 
1743. The currently selected range of cells STIM^range 1748 is itself 
characterised by a number of rows STIM_height 1746 and by a number of 
columns STIM^width 1745. Four other ranges of cells can now be identified 
within the current sheet 1740: the range of cells 
STIM_horizontaUlushed_range 1750 which is located on the same rows than 
the range of cells STIM^range 1748. but in the STIM^width 1745 rightmost 
columns; the range of cells STIM_verticalJlushed_range 1752 which is 
located on the same columns than the range of cells STIM^range 1748, but 
in the STIMJieight 1746 bottom rows; the range of cells 
STIMJhorizontalJkept^range 1749 located between the ranges of cells 
STIM^range 1748 and STIM_horizontalJlushed_range 1750; and the range 
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of cells STIM^verticaLkepLrange 1751 located between the ranges of cells 
STIM^range 1748 and STIM_verticalJlushed_range 1752. Finally the FIG 
17D also shows 6 existing scalable template instances: the ranges of cells 
STIM_horizontal_cutJn$tance 1753, STIM_vertical_cutJnstance 1754, 
STIMJiorizontaljshearedJnstance 1 755, STIM^verticaLshearedJnstance 
1756, STIM_verticaLflu$hedJnstance 1757, 

STIM_horizontaUlushedJnstance 1 758. 

Referring now to FIG 17E, the "horizontal insert" mode is illustrated by the 
updated current sheet 1760, resulting from the insertion of a number of rows 
equal to STIM_height 1746 at the position occupied by the currently selected 
cell 1747 within the currently selected range of cells which now takes the 
position 1761. The insertion of the new rows may have some impact on 
existing instances. First any Instance like the STIM_horizontaLcutJnstance 
1753 (which crossed the row of the currently selected cell 1747) is cut into 
two pieces: the top piece 1762 which was located above the row of the 
cun-ently selected cell 1747 and the bottom piece 1763 which was located 
below the row of the currently selected cell 1747. Second any instance like 
the STIM^verticaLflushedJnstance 1757 (which was overlapping the last 
STIM_height 1746 rows) is partially or totally flushed away from the current 
sheet, so that only a sub-set of it (possibly void) 1764 remains within the limits 
of the current sheet 1760. Third any data previously located within the last 
STIM^height 1746 rows is now pushed away from the current sheet 1760. As 
previously explained, if one of the corrupted existing instance is a critical 
instance, then the insertion operation would be considered as impossible, so 
that the "Insert' push-button 1623 remains disabled. OthenA/ise the insertion 
operation is performed, and any existing impacted scalable template instance 
will no longer be considered as a scalable template instance: 

Refening now to FIG 17F, the 'Vertical insert" mode is Illustrated by the 
updated current sheet 1770, resulting from the Inserlion of a number of 
columns equal to STIMjwidth 1745 at the position occupied by the cun-ently 
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selected cell 1747 within the currently selected range of cells which now takes 
the position 1771. The insertion of the new columns may have some impact 
on existing instances. First any instance like the STIM_vertical_ciJtJnstance 
1754 (which crossed the column of the cun^ently selected cell 1747) is cut into 

5 two pieces: the left piece 1772 which was located oh the left of the column of 

the currently selected cell 1747 and the right piece 1773 which was located 
on the right of the column of the currently selected cell 1747. Second any 
instance like the STIM_horizontaLf lushed Jnstance 1758 (which was 
overlapping the last STIM^width 1745 columns) is partially or totally flushed 

10 away from the current sheet, so that only a sub-set of it (possibly void) 1774 

remains within the limits of the current sheet 1770. third any data previously 
located within the rightmost STIM^width 1745 columns is now pushed away 
from the current sheet 1770 in an area 1776. As previously explained, if one 
of the corrupted existing instance is a critical instance, then the insertion 

IS operation would be considered as impossible, so that the "Insert push-button 

1623 remains disabled. Othen^/ise the insertion operation is perfonmed, and 
any existing impacted scalable template instance will no longer be considered 
as a scalable template instance. 

Referring now to FIG 17G, the "horizontal insert by range" mode is illustrated 
20 by the updated current sheet 1780, resulting from the insertion within range of 

a number of rows equal to STIMJieight 1746 at the position occupied by the 
currently selected cell 1747 within the currently selected range of cells which 
now takes the position 1781. With this mode, the two ranges of cells 
STIM_range 1748 and STIM^verticaLkepLrange 1751 are moved down by a 
25 number of rows equal to STIM_height 1746, so that space is left available for 

the new insertion 1781, and so that the bottom range of cells 
STIM_verticaUlushed_range 1752 is moved away from the limits of the 
current sheet 1780. The range move may have some impact on existing 
instances. First any instance like the STIM^verticaLcutJnstance 1754 and 
30 the STIM^verticaLshearedJnstance 1756 (which partially overiapped the two 

ranges of cells 1748 and 1751 moved down) are sheared into two pieces: the 
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left pieces 1782 and 1785 and the right pieces 1783 and 1784. Second any 
instance which was overiapping the range . of cells 
STIM_v0rticaLflu$hed_range 1752 Is partially or totally flushed away from the 
current sheet, so that only a sub-set of it (possibly void)' remains within the 
limits of the current sheet 1780. Third any data previously located within the 
range of cells STtM_verticaLflushed_rangeMS2 is now pushed away from 
the current sheet 1780 in an area 1786. As previously explained, if one of the 
corrupted existing instance is a critical instance, then the insertion operation 
would be considered as impossiblie; so that the "/nserf . push-button leizs 
remains disabled. Othenvise the insertion operation is perfonneid, and any 
existing impacted scalable template instance will no longer be considered as 
a scalable template instance. 

Referring now to FIG 17H, the "vertical insert by range" mode i§ Illustrated by 
the updated cun:ent sheet 1790, resulting from the insertion within range of a 
number of columns equal to STIM_width 1745 at the positiori occupied by the 
currently selectefd cell 1747 within the currently selected range of cells which 
now takes the position 1791. With this mode, the two ranges of cells 
STIM^range 1748 and STIM^horizontaLkepLrange 1749 are moved, right by 
a number of . columns equal to STIM_width 1745, so that space is left 
available for the new insertion 1791, and so that the rightmost range of cells 
STIMJiorizontalJIushed^range 1750 is moved away from the limits of the 
current sheet 1790 in an area 1798. The range move may have some impact 
on existing. instances. First any instance like the 
STIM^horizontaLcutJnstance 1753, the. STIM_verticaLcutJnstance 1754, 
and the STIM^horizontaLshearedJnstance 1755 (which partially overlapped 
the two ranges of cells 1748 and 1749 moved rights) are sheared into two 
pieces: the top pieces 1793, 1794 and 1797 and the bottom pieces 1792, 
1795 and 1796. Second any instance which was overlapping the range of 
cells STIM^horizontalJIushed^range 1750 is partially or totally flushed away 
from the current sheet 1790, so that only a sub-set of it (possibly void) 
remains within the limits of the current sheet 1790. Third any data previously 
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located within the range of cells STlMJhorizontaUlushed^range 1750 is now 
pushed away from the cunrent sheet 1790 in an area 1798. As previously 
explained, if one of the comipted existing instance is a critical instance, then 
the insertion operation would be considered as impossible, so that the "Inserf 
push-button 1623 remains disabled. Othen/vise the Insertion operation is 
perfomied, and any existing impacted scalable template instance will no 
longer be considered as a scalable template instance. 

3. Third Operation : Removal of Elements from a Defined Scalable Template 
Instance 

The third operation occurs when the spreadsheet user decides, based on his or 
her own criteria not detailed here, either: 

• to* remove some elements from a defined scalable template instance, or 

• to clear the content of some elements within a defined scalable template 
instance, or 

• to delete a whole defined scalable template instance, or . 

• even to delete some spreadsheet cells or columns or rows from the current 
sheet. 

In a preferred embodiment of the present invention, this operation comprises the 
following steps: 

• a. The spreadsheet user first selects a range of cells of his/her choice by 
using conventional means, such as but not limited to the pointing device 105 
or the keyboard 104, 

• b. Scalable Template Instance Deletion Manager 

Then the spreadsheet user invokes thanks to conventional means available in 
spreadsheet environment, such as (but not limited to) 

• dedicated push-buttons, 

• keyboard entry short cuts, 

• menu or sub-menu entries, 
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an original specific command called "Scalable Template Instance Deletion 
Managef which enriches the conventional means for deleting cells or rows or 
columns within a spreadsheet. In a preferred embodiment of the present 
invention, the "Scalable Template Instance Deletion Manager" command 
is invoked by using the same set of means as the one available in 
conventional electronic spreadsheets for clearing the content of a single cell 
or of a range of cells or for removing cells or rows or columns within a sheet, 
such as but not limited to 

• keying the "Delete" key on the keyboard 104, or 

• clicking with the pointing device 105 on a "Delete" sub-menu entry of the 
"Range" menu entry, or 

• keying the "Ctri-" key on the keyboard 104. 

When the command is invoked, a test is first perfomned to detennine if the 
currently selected cell belongs or not to an existing scalable template 
instance. 

If it is the case, then a second test is perfomied to determine the relative 
position of the currently selected range of cells within this scalable template 
instance, which will be referred to as the current scalable template instance. 
If the currently selected range of cells is overiapping, even . partially, the 
header part or the footer part of the current scalable template instance, then 
the deletion operation cannot consist in removing selected elements and 
meta-elements as the resulting scalable template Instance would be 
cpn^upted. Indeed the current scalable template instance abides by its 
associated scalable template which defines a structure comprising both 
elements and meta-elements, as the second test has shown that the cun-ent 
scalable template instance comprises either a footer part, or a header part, or 
both. Should at least a meta-eiement be removed from one of these parts, 
then the structure of the current scalable template instance would no longer 
abide by the structure of the associated scalable template. To globally 
preserve. the structure of the current scalable template Instance, the deletion 
operation must, statically keep the existing meta-elements according to the 
structure defined by the associated scalable template. Within this structure, 
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the scalable template defines cells, within each element or meta-elements, 
that can be specified either as "IN" cells or as "OUT cells. As the "IN" cells 
are those receiving spreadsheet user input, their content can be cleared 
Without jeopardizing the global structure of the cun^ent scalable template 
instance. It is not the case for the "OUT* dells which should therefore be kept 
untouched. The determination of the IN" cells to be cleared belongs to the 
spreadsheet user, under the control of the method which, in this specific 
case, statically manages the meta-elements. Two different sets of "IN" cells 
can be cleared: first the set of "IN" cells which, belong to the currently selected 
range of cells, and second the set of "IN" cells which belong to the current 
scalable template instance elements and/or meta-elements sharing the same 
rows as the currently selected range of cells. Finally; besides this static 
management of meta-elements, another possible option consists in deleting 
the complete current scalable template instance. Thus the only available 
modes of deletion are: 

• the mode "delete_1N_fieldsjn_selected_range" where are cleared the 
"IN" cells within the currently selected range of cells, 

• the mode "delete_IN_fieldsjn_selected_rows" where are cleared the "IN" 
cells found within the scalable template instance elements and/or 
meta-elements located on the same rows as the currently selected range 
of cells, and 

• The mode "delete_selected_instance" where is deleted the whole scalable 
template instance containing the currently selected cell, by restoring in 
place void cells with default display attributes. 

If the currently selected range of cells is found outside the header part and 
the footer part of the current scalable template instance, but within the body 
part of the cun^ent scalable template instance, then a fourth mode of deletion 
becomes possible: 

• the "delete_selected_elements" mode where are removed from the 
scalable template instance the elements sharing the same rows as the 
currently selected range of cells, by copy-pasting the undemeath elements 
(and possible meta-elements) onto the ones contained in the currently 
selected range of cells. 
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box 1608 is filled with the value of the local variable STIM_heightMG6. The label 
box 1607 is filled with the value of the local variable STlMJtooJhigh. The 6 label 
boxes 1604 are filled row after row, starting with the top row, from the left to the 
right, with the values of the following local variables in the following order 

• STIM^horizontaLcritical, 

• STIM_horizontaLother, 

• STIM^horizontaLdata, 

• StlM_horizontaLrange_critical, 

• STIM_horizontaLrange_other, 

• STIM_horizontaLrange_data. 

Then if the local variable STIM_mode takes the respective value 
HORizoNTAL_iNSERT, or HORizoNTALjNSERT_BY_RANGE, then the option button 1606, or 
1605 displays alone a black point. 

Finally the "InserT push-button 1603 is disabled as soon as one of the following 
local variables takes the value "yes": STlMjooJhigh, STIM_horizontaLcritical 
(only taken into account if the local variable Sr/M_moc/e is equal to 
horizontaljnsert), STIM_horizontaLrange_critical (only taki9n into account if the 
local variable STIM^mode is equal to horizontaljnsert_by_range); otherwise the 
''Insert push-button 1603 is enabled. . . 

At step 151 1, the method is waiting for any user action on the Scalable Template 
Insert Manager Dialog Box 1600. Such user action is typically resulting from a 
click with the pointing device 105, but take other similar forms such as, but not 
limited to a specific combination of key on the keyboard 104, or any other similar 
means not further specified here. 

At step 1512, a user action on the Scalable Template Insert Manager Dialog Box 
1600 is detected. 

• If the user action is a click on the Insert push-button 1603, then control is 
given to step 1525; 
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variable STIMJhorizontaLdata takes the value "yes". 

Second the horizontal jnsert_by_range mode of instanciation is investigated. 

• If there exists at least one existing scalable template instance whose ""Criticar 
5 field 755 takes the value "yes" and which partially overiaps the range of cells 

constituted by the concatenation of the range of cells 
STIM_verticaLkept_range 1711 with the range of cells which is derived from 
the range of cells STIMJnstance^range 1713 by removing the rows above the 
currently selected cell 1707, or which partially overiaps the range of cells 
10 STIM_verticaUlushed_range 1712, or which is included in the range of cells 
STIM_verticaLflushed_range 1712, then the local test variable 
STIM_horizontaLrange_critical takes the value *Ves"; otherwise the local test 
variable STIM_horizontaLrange_critical takes the valu.e "no". 

• If there exists at least one existing scalable template instance whose ""Criticar 
15 field 755 takes the value "no" and which partially overiaps the range of cells 

constituted by the concatenation of the range of cells 
STIM_verticaLkept_range 1711 with the range of cells which is derived from 
the range of cells STIM_instance_range 1713 by removing the rows above the 
currently selected cell 1707, or which partially overiaps the range of cells 
20 STIM_verticaUlushed_range 1712, or which is included in the range of cells 
STIM_verticaUlushed_range 1712, then the local test variable 
STlMJhorizontal_range_other takes the value ^Ves"; othenAfise the local test 
variable STIM^horizontaLrange^otherXakes the value "no". 

• If all the cells within the range of cells STIM_verticaUlushed_range 1712 are 
25 empty (containing none data), then the local test variable 

STIM__horizontaLrange_data takes the value "no"; othenA/ise the local test 
variable STIM_horizontaLrange_data takes the value *Ves". 

• At step 1510, the Scalable Template Insert Manager Dialog Box 1600 is 
displayed on the display device 106. The "Criticar check box 1610 displays a 
30 check mark if the local variable STIM^critical takes the value "yes"; othenA^ise 
(value W), the "CnticaP check box 1610 is kept with a blank empty display. The 
label box 1611 Is initialised with the value of the local variable ST_name. The text 
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scalable template Instance or data. These tests require to parse the STIT table 
750, and to visit each record 751 to learn the address {''Address field 752) and 
the importance {^CriticaF field 755) of every already defined scalable template 
instance. These tests evaluate either if two given ranges of cells partially overlap 
5 (meaning that there exist in the first range of cells at least one cell belonging to 
the second range of cells and at. least one cell not belonging to the second range 
of cells) or if a ifirst given range of cells is included within a second given range of 
cells (meaning that every cell belonging to the first range of cells belongs too to 
the second range of cells). Different conventional range comparison techniques 
10 . can be used for evaluating either range partial overlapping or range inclusion, 
without departing from the spirit of the present invention; they will not be 
described in the preferred embodiment of the present invention. 

First the horizontal_insert mode of instanciation is investigated. 

15 • If there exists at least one existing scalable template instance whose "Criticar 
field 755 takes the value "yes" and which partially overlaps. the range of cells 
made of the entire row where is located the currently selected cell 1707, or 
which partially overlaps the range of cells constituted by the last bottom 
STIMJheight 1706 rows, or which is included in the range of cells constituted 

20 by the last bottom STIMJheight 1706 rows, then the local test variable 
STIM^horizontaLcritical takes the value "yes"; othenA^ise the local test variable 
STIM_horizontaLcritical takes the value "no". 

• If there exists at least one existing scalable template Instance whose. "Cnf/car 
field 755 takes the value "no" and which partially overlaps the range of cells 

25 made of the entire row where Is located the currently selected cell 1707, or 
which partially overlaps the range of cells constituted by the last bottom 
STIMJheight 1706 rows, or which is included in the range of cells constituted 
by the last bottom STIMJheight 1706 rows, then the local test variable 
STIMjhorizontaLother takes the value "yes"; othenA^ise the local test variable 

30 STIM_horizontal_otherXakes the value "no". 

• If all the cells within the range of cells constituted by the last bottom 
STIMJheight 1706 rows are empty (containing none data), then the local test 
variable STIMJiorizontaLdata takes the value "no"; othenA/ise the local test 
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warning message in a pop-up window, or in a status bar area, but any other 
similar means could be used instead, without departing from the spirit of the 
invention. Then the user is prompted to either cancel the cunrent "Insertion" 
operation, or to pursue it. This can typically be done by displaying on the display 
device 106 a prompting message in a pop-up window, but any other similar 
means could be used Instead, without departing from the spirit of the invention. 
Once the user has made his choice through conventional means such as clicking 
with the pointing device 105 on an "Cancel" or "Continue" push-button present 
within a prompting message pop-up window, or any other similar means without 
departing from the spirit of the invention; control Is given to step 1501 if the 
spreadsheet user decision is to cancel the operation, or to step 1507 if the 
spreadsheet user decision is to continue the operation. 

At step 1507, the STIT table 750 is visited to remove from it the record 751 
corresponding to the current scalable template Instance identified at step 1503 
and containing the currently selected ceil 1707. Then the "Reference 
Housekeeping Process", as described in step 1414 of the Scalable Template 
Instanciator method, is executed, before giving control to step 1508. 

At step 1508, two sums are perfonfned to check If the insertion within the cun^nt 
scalable template instance will fit within the boundaries, of the cu.n-ent sheet 1700 
and within the m^imum size of the scalable template instance. 

• If the sum of the local variables STIMJieight 1706 and STIM_element is found 
greater than the local variable STIM_max, then a local variable STIM_too_hlgh 
is set to "yes"; othenvise it is set to "no". 

• If the sum of the local variables STIM_offset_height 1704 and 
STIM_heacler_$ize and STIM_element and STIM_footer_size and 
STIM_heightMm is found greater than the local variable STIM_sheet_height 
1702, then a local variable STIM_too_high is set to "yes"; othenwise it is set to 
"no". 

At step 1509, several tests are perfomied to evaluate the potential impact of the 
insertion, according to two possible insertion modes, on any already existing 
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the currently selected cell 1707 is used to Inttialise the local variable 
STIM_range_off$et_height 1709 corresponding to the number of rows between 
the top left cell of the cunrent sheet 1700 and the currently selected cell 1707. 
Then the number of rows of the cun-ently selected range of cells STIM^range 
1708 is represented by the local variable STIM_height 1706. Then the position of 
the top left cell of the range of cells STIMJnstance^range 1713 is first 
represented by the local variables STIM_offseLwidth 1703 and 
STIM_offset_height 1704 corresponding respectively to the number of columns 
and of rows between the top left cell of the current sheet 1320 and the top left 
cell of the range of cells STIMJnstance^range 1713. Then the range of cells 
STIM_verticaUlushed_range 1712 is detenmined as the range of cells sharing 
the same columns as STIMJnstance__range 1713, and occupying.; the. 
SflM^height 1706 bottom columns of the current sheet 1700. Then the range of 
cells STIM^verticaLkepLrange 1711 is detemnined as the range of cells sharing 
the same columns as STIMJnstance^range 1713, and occupying the rows 
located between those of STIMJnstance^range 1713 and 
STIM_verticaLflushecl_range 1712. 

At step 1505, a test is perfomied to test If the currently selected cell 1707 is 
located either within the header part or the footer part of the current scalable 
template instance, or within an element of the current scalable template instance. 
If the sum of the local variables STIM_offseLheight 1704 and STIM^header^size 
is less than or equal to the local variable STIM_range_offset_height 1709 and if 
the local variable STIM_range_offset_height 1709 is less than or equal to the 
sum of the local variables STIM_offseLheight 1704, STIM_header_size, and 
STIM^element, then the currently selected cell 1707 is outside the header and 
footer parts of the current scalable template Instance and control is given to step 
1508; othenA/ise control is given to step 1506. 

At step 1506, a warning message notification is issued for infomiing the user that 
the current scalable template instance may be corrupted if the insertion operation 
is pursued. This can typically be done by displaying on the display device 106 a 
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cells, then the top left cell of the currently selected range of cells becomes the 
currently selected ceil. 

• At step 1503, a test is performed to check if the currently selected cell is located 
within an existing scalable template instance. This test is perfomied by parsing 

5 the STIT table 750 and visiting in each record 751 the "Address field 752 to 
detemnine if the range of cells address specified in this field does include the 
address of the Individual currently selected cell 1707. If it is the case, then the 
currently selected cell 1707 is contained in a scalable template instance named 
STIMJnsfance_range 1713 and control is given to step 1504 ; otheoArise control 
10 is given to step 1513. 

• At step 1504, the record 751 found at the step 1503 is first retrieved to initialise 
local variables from its fields describing the scalable template instance 
S77/W_/nsfance_ransfe 1713: 

• the local variable ST^name Is initialised with the value of the.field "SF 753; 

15 • the local variable STIM^element is initialised with the value of the "Element r 
field 754; 

• the local variable STIM_critical is initialised with the value of the ""Criticar field 
755; 

• the local variable STIM_header_size is initialised with the value of the "Header 
20 S/ze^ field 756; 

• the local variable STIMJooter_size is initialised wth the value of the ""Footer 
SizeT field 757; 

Then the local variable ST^name is used to parse the STT table 720 in order to 
find the record 721 whose "Name" field 722 matches the parameter ST_name. 

25 . Once this record 721 is found, its field "/Wax Element 726 is memorized as the 
local variable STIM_max. Then another local variable STIM^sheet_width 1701 is 
initialised with the total number of columns in the current sheet 1700. Then 
another local variable STIM_sheetJhelght 1702 is initialised with the total 
number of rows in the current sheet 1700. Then another local variable 

30 STIM^mode is initialised with the value HORizoNTALjNSEm-. Then the position of 
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value INSTANCE. Then the EPT table 710 is visited to identify the corresponding 
record 711 whose "A/ame^ field 712 matches this element or meta-element profile 
name. Once found, the "referenced" attribute 719 of the • Typtf' field 717 of this 
record 71 1 is set to the value instance. 

5 • At step 1428, the currently selected cell is moved downwards by one row. Then 
control is given to step 1422. 

• At step 1429, the Scalable Template Instanciator Dialog Box 1300 is closed so 
that it disappears from the display device 106. Finally control is given back to the 
initial step 1401 for processing any future Scalable Template Instanciator 

10 command. 

E6. Scalable Template Instance Insertion Manager method 

The method for changing an existing scalable templjate instande by introducing new 
elements used in the prefenred embodiment of the present invention is summarised 
in flowchart 1500 of FIG 15. This method can be seen as the processing of the 
15 Scalable Template Instance Insertion Manager con\mar\d.\ 

• At step 1501, the method is in its default state, waiting for. ah event to initiate the 
process. 

• At step 1502, the Scalable Template Instance Insertion Manager command is 
detected, as a result of a user action. This action can be for instance: 

20 • a specific combination of key on the keyboard 1 04, or 

• the click of the pointing device 105 on a specific button or menu entry or 
sub-menu entry, or 

• any other similar means not further specified here. 

When the Scalable Template Instance Insertion Manager command is 
25 detected, the current spreadsheet selection corresponds to a range of cells, 
possibly reduced to a single individual cell, which is known as the currently 
selected range of cells and which comprises the currently selected cell. If this 
cun^ently selected cell is not the top left cell within the currently selected range of 
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• At step 1422, the EPT table 710 is parsed to find the record 711 whose "A/ame" 
field 712 is found equal to the profile name within the current pair. Once this 
record 711 is found, its "Description Ptf field 714 is retrieved to locate in memory 
the range of cells illustrating the profile. This description of the profile is 

5 copy-pasted by value only onto the cunrently selected cell, so that the 
corresponding row within the STLrange receives the profile initial values. Then 
the EFT table 700 is parsed to find the record 701 whose "A/ame^ field 702 is 
found equal to th9 fomiat name within the cunrent pair. Once this record 701 is 
found, its ''Description Ptf field 704 is retrieved to locate in memory the range of 

10 cells illustrating the fomriat. This description of the profile is copy-pasted by 
attribute only onto the currently selected cell, so that the corresponding row 
within the STI_range receives the fomnat attributes. 

• At step 1423 a test is perfomned to check if the current pair (fomiat name, profile 
name) corresponds to an element or to a meta-element. In the first case, control 

15 is given to step 1424, and in the second case control is given to step 1425. 

• At step 1424, the local variable STIJndex is decremented by 1 (one). Then 
control is given to step 1426. 

• At step 1425, a test is perfomied to check if the current pair (fomiat name, profile 
name) is the last one 763 within the STDT table 760. If it is the case, the control 

20 is given to step 1429, othenArise control is given to step 1427. 

• At step 1426, a test is performed to check if the local variable STIJndex is equal 
to 0 (zero). If it is the case, then control is given to step 1425, othenwise control is 
given to step 1428. 

• At step 1427, the pair of names (format name, profile name) following the current 
25 one in the STDT table 760 becomes the current pair of names. Then the EFT 

table 700 is visited to identify the corresponding record 701 whose "A/ame^ field 
702 matches this element or meta-element fomiat name. Once found, the 
"referenced" attribute 709 of the "Type?' field 707 of this record 701 is set to the 
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At Step 1418, the range of cells STLrange 1328 is selected to become the 
currently selected range of cells, with the curently selected cell being kept in its 
fonner position 1327 and then a regular operation of "row insertion within 
selected range" is perfomned. Then control is given to step 1 421 . 

At step 1419, the range of cells STLrange 1328 is selected to become the 
currently selected range of cells, with the currently selected cell being kept in its 
fomner position 1327 and then a regular operation of "column insertion" is 
performed. Then control is given to step 1421 . . 

At step 1420, the range of cells STLrange 1328 is selected to become the 
currently selected range of cells, with the currently selected cell being kept in its 
fomner position 1327 and then a regular operation of "row insertion" is perfonmed. 
Then control is given to step 1421. 

At. step 1421, a local variable STUndex is initialised to the value taken by the 
local variable STLelement Then , the STT. table. 720 Is parsed to identify the 
record 721 whose "Namef field 722 matches the value of. the. local variable 
STjname. Within this record 721 is retrieved the "Description Ptf field 724 
allowing to locate in memory the STDT table 760 associated to the scalable 
template that the new scalable template instance to be created will abide by. 
Then the first pair 761 of element or meta-element fomiat name and element or 
meta-element profile name found within this STDT table 760 is set as the current 
pair of names: (fonnat name, profile name). Then the EFT table 700. is visited to 
identify the corresponding record 701 whose "A/ame" field 702 matches . this 
element or meta-element fonnat name. Once found, the "referenced" attribute 
709 of the "Type" field 707 of this record 701 is set to the value instance. Then 
the EPT table 710 is visited to identify the corresponding record 711 whose 
"Nam^' field. 712 matches this element or meta-element profile name. Once 
found, the "referenced" attribute 719 of the "Type^ field 717 of this record 711 Is 
set to the value instance. 
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variable ST^name, the ""Element #" field 754 is initialised with the value of the 
local variable STLelement, the ""Criticar field 755 is initialised with the value of 
the local variable STLcritical, the "Header Siz^ field 756 is initialised with the 
number of meta-elements constituting the header part of the new scalable 
template instance (this number being equal to the number of pairs In the header 
part 767 of the STDT table 760 associated to the scalable template that the new 
scalable template instance will abide by), and the ''Footer SizeT field 757 is 
initialised with the number of meta-elements constituting the footer part of the 
new scalable template Instance (this number being equal to the number of pairs 
in the footer part 766 of the STDT table. 760 associated to the scalable template 
abided by the new scalable template instance). Then the STT table 720 is 
scanned to identify the record 721 whose "A/ame^' field is found equal to the local 
variable Sr_name. Once found, the "referenced" attribute 729 within the 'Typ^' 
field 727 of this record 721 is set to the value instance. 

At step .1416 a test is perfomned to check the value of the local variable 
STLmode. 

• If this value is found equal to overlay then control is given to step 1421 , 

• If this value is found equal to horizontaljnsert then control is given to step 
1420, 

• If this value is found equal to horizontaljnsert_by_range then control is given 
to step 1418, 

• If this value is found equal to verticaljnsert then control is given to step 
1419, 

• If this value is found equal to verticaljnsert_by_range then control is given to 
. step 1417. 

At step 1417, the range of cells STLrange 1328 is selected to become the 
currently selected range of cells, with the currently selected cell being kept in its 
former position 1327 and then a regular operation of "column insertion within 
selected range" is perfomied. Then control is given to step 1421. 
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720 (with "NameT field 722 matching this "Sr field 753) comprises a ""Description 
Ptf field 724 pointing to another STDT table 760 where the same name 
STLremoved_name is specified. If no other record 751 matching this criteria is 
found in. the STIT table 750, then it means that this object (either a format or a 
3. profile) is no longer referenced in an existing scalable template instance. If this 
object is a format name, then the EFT table 700 is scanned to first identify the 
record 701 whose "Nam^ field 702 matches this fomiiat name 
. STLremoved_name, and then when found the "referenced" attribute 709 of the 
""Typ^ field 707 within this found record 701 is set to the value template. If this 

10 object is a profile name, then the EPT table 710 is scanned to first identify the 
record 711 whose "A/ame" field 712 matches this profile name 
STLremoved^name, and then when found the "referenced" attribute 719 of the 
"rype" field 717 within this found record 71 1 is set to the value template. Then for 
ejach name STLremoved_name, the STT table 720 is scanned to identify a 

15 record 721 whose "Description Ptf field 724 points to a. STDT table 760 
containing this name STI_removedjname. If no record 721 matching this criteria 
is found in the STT table 720, then it means that this object (either a format or a 
profile) is no longer referenced in an existing scalable template. If this object is a 
fomriat name, then the EFT table 700 is scanned to first identify the record 701 

20 whose "NameT field 702 matches this fomiat* name STI_removed__name, and 
then when found the "referenced" attribute 709 of the "Type" field 707 within this 
found record 701 is set to the value none. If this object is a profile name, then the 
EPT table 710 is scanned to first identify the record 711 whose "A/ame" field 712 
matches this profile name STI_removed_name, and then when found the 

25 "referenced" attribute 719 of the "Type^' field 717 within this found record 711 is 
set to the value none. All these operations are; repeated for each removed 
scalable template instance and constitute the "Reference Housekeeping 
Process". 

• At step 1415, a new record 751 is introduced in the STIT table 750. Within this 
30 record 751, the "AddressT field 752 is initialised with the address of the range of 
cells STI^range 1328. the "Sr field 753 is initialised with the value of the local 
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• At Step 1413, the local variable STLelement Is incremented by 1 (one), as long 
as its value remains less than or equal to the value of the local variable STLmax. 
Then control is given to step 1404. 

• At step 1414, the STIT table 750 Is visited to remove from it every record 751 
S corresponding to a scalable tenriplate instance corrupted by the introduction of 

the new instance, as identified during the step 1406 for the insertion mode 
represented by the local variable STLmode, 

Then the EFT, EPT and STT tables 700, 710 and 720 must be potentially 
updated to reflect any possible change in the way fomnats, or profiles, or scalable 
10 . templates are referenced, resulting from the removal of scalable template 
instances. This process, described hereafter, will be referred to as the 
"Reference Housekeeping Process". 

For each such removed scalable template instance, the associated record 751 
within the STIT table 750 contains a "Sr field 753 which- identifies the 

15 associated scalable template. If there is not other remaining record 751 in the 
STIT table 750 sharing the same value of the "Sr field 753 as the one of the 
removed record 751. and whose Address field 752 differs from the value 
"clipboard", then it means that the removed scalable template instance was the 
last one abiding by its associated scalable template. In this case, this "Sr field 

20 753 is used to scan the STT table 720 for identifying a record 721 whose "/Vame^ 
field 722 is equal to the "Sr field 753, and then to set within this found record 
721 the "referenced" attribute 729 of the "Type^ field 727 to the value none. Then 
in this same case, the scalable template STDT table 760 pointed by the 
Description Ptt" field 724 within this fourid record 721 of the STT table 720 must 

25 be scanned to determine if the removed scalable template instance was the last 
. one referencing any of the associated format or profile. For each name found in 
this STDT table 760 (referred to as STI_removed_,name either for a format name 
as found in the column 765, or for a profile name as found in the column 764), 
the STIT table 750 is scanned to identify any other record 751 whose ''Addres^' 

30 field 752 differs from the value "clipboard" and whose "Sr field 753 specifies 
another scalable template name whose associated record 721 in the STT table 
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Such user action is typically resulting from a click with the pointing device 105, 
but take other similar forms such as, but not limited to a specific combination of 
key on the keyboard 104, or any other similar means not further specified here. 

• At step 1409, a user action on the Scalable Template Instanciator Dialog Box 
S 1 300, or a change of the currently selected cell is detected. 

• If the user action is a click on the "Greater push-button 1303, then control is 
given to step 1414; 

• if the user action is a click on the upper part of the spin button 1313, then 
control is given to step 1413; • 

10 • if the user action is a click on the lower part of. the spin button 1313, then 
control is given to step 1412; 

• if the user action is a click on the ""Criticar check box 1314, then control is . 
given to step 1411; 

• if the user action is a click on one of the option buttons 1309, or 1308, or 1307* 
15 or 1306, or 1305, then control is given to step 1410; 

• if the user action is a click on the "Cancer push-button 1302, or on the 
. closing-window push-button 1 301 , then control is given to step 1 429; 

• finally if the user action is a change in the position of the currently selected 
cell, then control is given to step 1404. 

20 • At step 1410, the local variable STLmode takes the value overlay,, or 

HORIZONTAL_INSERT, Or HORIZONTALJNSERT_BY_RANGE, Or VERTICALi:.INSERT, Or 

VERTicAL_iNSERT_BY_RANGE if the Spreadsheet user has respectively clicked with . 
the pointing device 105 on the option button 1309, or 1308, or 1307, or 1306, 6r 
1305. Then control is given to step 1404. 

25 • At step 1411, the local variable STLcritical is updated in order to swap between 
the values "yes" and "no". Then control is given to step 1404. 

• At step 1412, the local variable STLelement is decremented by 1 (one), as long 
as its value remains greater than or equal to the value of the local variable 
STI_min. Then control is given to step 1404. 
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• At Step 1407, the Scalable Template Instanciator Dialog Box 1300 is displayed 
on the display device 106. The "Criticar check box 1314. displays a check mark if 
the local variable STLcritical takes the value "yes"; otherwise (value "no"), the 
''Criticar check box 1314 is kept with a blank empty display. The label box 1315 

S is initialised with the value of the local variable ST_name, The text box 1312 is 
filled with the value of the local variable STLelement The label box 1311 is filled 
with the value of the local variable STUoojwide and the label box 1310 is filled 
with the value of the local variable STlJtooJhigh. The 15 label boxes 1304 are 
filled row after row, starting with the top row, from the left to the right, with the 

10 values of the following local variables in the following order: STI_overlay_cntical, 
STLoverlay^other, STLoverlay^data, STLhorizontaLcritical, 

STLhorizontaLother, STLhorizontaLdata, STI_horizontaLrange_critical, 
STLhorizontaLrange^othen STLhorizontaLrange^data, STI_vertical_critical, 
STLverticaLother, STLverticaLdata, STI_verticaLrange_critical, 

15 STI_verticaLrange_othen STLverticaLrange__data. 

Then if the local variable STLmode takes the respective value overlay, or 

HORIZONTALJNSEBT, Or HORlZONTAL_INSERT_BY_RANGE, Or VERTjCALJNSERT, Or 

VERTicAL_iNSERT_BY„RANQE, then the optlon button "Over/a/. 1309, or ''Horizontal 
Insert' 1308, or "Horizontal Insert by RangeT 1307, or "Vertical Inserf 1306, or 

20 "Vertical Insert by Rang^ 1305 displays alone a black point;. Finally the "Create' 
push-bu.tton 1303 is disabled as soon as one of the following local viariables 
takes the value "yes": STIJtoo^wide, STIJooJhigh, STLoveriay_critical (only 
taken into acco.unt if the local variable STLmode is equal to overlay) , 
STLhorizontaLcritical (only taken into account if the local variable STLmode is 

25 equal to horizontal jnsert), STLverticaLcritical (only taken into account if the 
local variable STLmode is equal to vertical_insert), 
STLhorizontaLrange^critical (only taken into account if the local variable 
STLmode is equal to horizontaljnsert_by_range), STLverticaLrange^critical 
(only taken into account if the local variable STLmode is equal to 

30 vertical_insert_by_range); othenA^ise the "Created push-button 1303 is enabled. 

• At step 1408, the method is waiting for any user action on the Scalable Template 
Instanciator Dialog Box 1300, or on any change of the currently selected cell. 
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which partially overlaps the range of cells constituted by the last right 
STLwidth 1325 columns, or which is included in the range of cells constituted 
by the last right STLwidth 1325 columns, then the local test variable 
STLverticaLother takes the value "yes"; othenrtrise. the local test variable 
5 STLverticaLother takes the value "no". 

• If all the cells within the range of cells cpnstituted by the last right STI^width 
1325 columns are empty (containing no data), theri the local test variable 
STI_vertical_data takes the value "no"; othjarwise the local test variable 
ST/_ve/t/ca/_c/afa takes the value 'Ves". 

10 

Fifth the vertical_insert_by_range mode of instanciatiori. is investigated. 

• If there exists at least one existing scalable template instance whose ''Criticar 
field 755 takes the value "yes" and which partially overiaps the range of cells 
constituted by the concatenation of the two ranges, of cells STI_range 1328 

15 and STLhohzontalJ<ept_rar)ge 1329, or which partially overiaps the range of 
cells STI_horizontal_flushed_range 1330, or which is. included in the range of 
cells STI_horizontal_flu3hed_range 1330, then the local test variable 
. STiyertical_range_critical takes the value "yes"; othemise the local test 
variable SrLv^©/f/ca/_Aange_cr/f/ca/ takes the value "no". 

20 • If there exists at least one existing scalable template instance whose "CriticaP 
field 755 takes the value "no" and which partially overiaps the range of cells 
constituted by the concatenation of the two ranges of cells STI^range 1328 
at)d STLhorizontal^kept^range 1329, or which partially overiaps the range of 
cells STLhorizontaLflushed^range 1330, or which is included in the range of 

25 cells STI_horizontaLflushed_range 1330, then the local test variable 
STI_verlicaLrange_other takes the value ?Ves"; otherwise the local test 
variable STI_vertical__range_other takes the value "no". 

• If all the cells within the range of cells STI^horizontalJIushed^rarige 1330 are 
empty (containing none data), then the local test variable 

30 STI_vertical_range_data takes the value "no"; othenA^ise the local test variable 
STI_verticaLrange_data takes the value \es". 
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• If there exists at least one existing scalable template instance whose "Criticar 
field 755 takes the value "Ves" and which partially overlaps the range of cells 
constituted by the concatenation of the two ranges of cells STLrange 1328 
and STLverticaLkepLrBnge 1331, or which partially overlaps the range of 

S cells STLverticaUlushed^range t332, or which is included in the range of 
cells STLverticaLflushed_^range 1332, then the local test variable 
STLhorizontaLrange^critical takes the value 'Ves"; othenA^ise the local test 
variable STLhorizontal_range_critical takes the value "no". 

• If there exists at least one existing scalable template instance whose "Cnticaf 
10 field 755 takes the value ''no" and which partially overlaps the range of cells 

constituted by the concatenation of the two ranges of cells STLrange 1328 
and STLverticaLkepLrange 1331, or which partially overlaps the range of 
cells STI_verticaUlushecl_range 1332, or which is included in the range of 
cells STLverticaLflushed^range 1332, then the local test variable 
15 STLhorizontal_range_other takes the value "yes"; othenwise the local test 
variable STLhorizontaLrange^other takes the value "no". 

• If all the cells within the range of cells STLverticaUlushed_range 1332 are 
empty (containing none data), then the local test variable 
STI__horizontaLrange_data takes the value "no"; othenwise the local test 

20 variable STIJhorizontaLrange^data takes the value "yes". 

Fourth the vertical jNSEm- mode of instanciation is investigated. 

• If there exists at least one existing scalable template instance whose "Criticar 
field 755 takes the value ^'Es" and which partially overiaps the range of cells 

25 made of the entire column where is located the currently selected cell 1327, or 
which partially overiaps the range of cells constituted by the last right 
STLwidth 1325 columns, or which is included in the range of cells constituted 
by the last right STLwidth 1325 columns, then the local test variable 
STLverticaLcritical takes the value "yes"; othenwise the local test variable 

30 STLverticaLcritical takes the value "no". 

• If there exists at least one existing scalable template instance whose "Criticar 
field 755 takes the value "no" and which partially, overiaps the range of cells 
made of the entire column where is located the cun^ently selected cell 1327, or 
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value *Ves"; otherwise the local test variable STLoverlayjcritical takes the 
value "no". 

• If there exists at least one existing scalable template instance whose "CriticaP 
field 755 takes the value "no" and which partially overiaps the range of cells 
STLrange 1328, then the local test variable SrLoi/©A/a>LOf/70r takes the value 
"yes"; othenA^ise the local test variable STLoverlay^otherXakes the value "no". 

• If all the cells within the range of cells STLrange 1328 are empty (containing 
none data), then the local test variable STIjoveriay^data takes the value "no"; 
othenwise the local test variable STLoverlay_data takes the value "yes". 

Second the horizontal_insert mode of instanciation is investigated. 

•. If there exists at least one existing scalable template instance whose "Criticar 
field 755 takes the value \es" and which partially overlaps the range of cells 
made of the entire row where is located the currently selected cell 1327, or 
which partially overlaps the range of cells, constituted by the last bottom 
STLheight 1326 rows, or which is included In. the range of cells constituted by 
the last bottom STLheight 1326 rows, then the. local test variable 
STLhonzontaLcritical takes the value 'Ves"; othenwise the local test variable 
STLhofizontaLcritical takes the value "no". 

• If there exists at least one existing scalable template instance whose '"Criticar 
field 755 takes the value "no" and which partially overiaps the range of cells 
made of the entire row where is located the currently selected cell 1327, or 
which partially overiaps the range of cells constituted by the last bottom 

. STLheight 132B rows, or which is included in the range of cells constituted by 
the . last bottom STLheight 1326 rows, then the local test variable 
STI_horizontal_other takes the value "yes"; othenA/ise the local test variable 
STI_horizontai_other takes the value "no". 

• If all the cells within the range of cells constituted by the last bottom 
STI__height 1326 rows are empty (containing none data), then the local test 
variable STI_horizontal_data takes the value "no"; othenA^ise the local test 
variable STI^horizontaLdata takes the value *Ves". 

Third the horizontaljnsertjy^range mode of instanciation is investigated. 
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Then the range of cells STI_vertical_kept_range 1331 is determined as the range 
of cells sharing the same columns as STLrange 1328, and occupying the rows 
located between those of STLrange 1328 and STLverticalJlushedjrange 1332. 

• At step 1405, two sums are perfonned to check if the future scalable template 
5 instance will fit within the boundaries of the current sheet 1320. 

• If the sum of the local variables STLoffset_width 1323 and STCwidth 1325 is 
found greater than the local variable STLsheeCwidth 1321, then a local 
variable STLtoo_wicle Is set to *Ves"; otherwise it is set to "no". 

• If the sum of the local variables STLoffset_height 1324 and STI_height 1326 
10 is found greater than the local variable STLsheet_height 1322, then a local 

variable STI_too_high is set to "yes"; othenwise.it is set to "no". 

• At step 1406, several tests are performed to evaluate the potential impact of the 
creation of the future scalable template instance, according to the five possible 
instanciation modes, on any already existing scalable template instance or data. 

15 These tests require to parse the STIT table 750, and to visit each record 751 to 
learn the address {"Address field 752) and the Importance (^CriticaF field 755) of 
every already defined scalable template instance. These tests evaluate either if 
two given ranges of cells partially overiap (meaning that there exist in the first 
range of cells at least one cell belonging to the second range of cells and at least 

20 one cell not belonging to the second range of cells) or If a first given range of 
cells is included within a second given range of cells (meaning that every cell 
belonging to the first range of cells belongs too to the second range of cells). 
Different conventional range comparison techniques can be used for evaluating 
either range partial overiapping or range inclusion, without departing from the 

25 spirit of the present invention; they will not be described in the preferred 
embodiment of the present invention. 

First the overlay mode of instanciation is investigated. 

• If there exists at least one existing scalable template instance whose "Criticar 
30 field 755 takes the value "yes" and which partially overiaps the range of cells 

STLrange 1328, then the local test variable STLoverlay^critical lakes the 
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Then another local variable STI_critical is initialised with the default value "yes". 
Then another local variable STLsheeCwidth 1321 is initialised with the total 
number of columns in the cun^ent sheet 1320. 

Then another local variable STLsheeLheight 1322 is initialised with the total 
5 number of rows in the current sheet 1320. 

Then another local variable STI_mode Is initialised with the value overlay. 

• At step 1404, some other local variables are first built or updated. The position of 
the currently selected cell 1327 is first represented by the local variables 
STLoffseLwidth A323 and STLoffseLheight ^324 corresponding respectively to 
10 the number of columns and of rows between the top left cell of the current sheet. 
1320 and the currently selected cell 1327. 

Then the number of rows of the future scalable template instance- is represented 
by the local variable STLheigtit 1326. computed as the sum of the local 
variables Sr/_mefa and STLe/emenf. 
15 Second some working ranges of cells are determined through the evaluation of 
their addresses. 

The range of cells STLrange 1328 corresponding to the future, scalable template 
instance is first determined as the range of cells with the currently selected cell 
1327 as the top left cell, and with a number of rows and columns respectively 

20 equal to STL/)e/g/7f 1326 and Si7_w/c/f/7 1325. 

Then the range of cells STIJhorizontaUlushed^range 1330 is deterfhihed as the 
range of cells sharing the same rows as STLrange 1328, and occupying the 
STLwidth 1325 rightmost columns of the current sheet 1320; 
Then the range of cells STLhorizontaLkepLrange 1329 is determined as the 

25 range of cells sharing the same rows as STLrange 1328, and occupying the 
columns located between those, of STLrange 1328 and 
STLhorizontaLflushedyange ^330. 

Then the range of ceWs STLverticaLflushed^range 1332 is determined as the 
range of cells sharing the sanfie columns as STLrange 1328, and occupying the 
30 STLheight 1 326 bottom columns of the current sheet 1 320. 
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disabled while the "Editor Space" sheet 675 was displayed are now enabled 
again. Finally control is given back to the initial step 1201 for processing any 
future Scalable Template Ed/for command. 

E5. Scalable Template Instanciator method 

S The method for creating a scalable template instance abiding by a defined scalable 
template used in the prefenred embodiment of the present invention is summarised 
in flowchart 1400 of FIG 14. This method can be seen as the processing of the 
Scalable Template Instanciator command. 

• At step 1401 , the method is in its default state, waiting for an event to initiate the 
10 process. 

• At step 1402, the Scalable Template Instanciator command is detected, as a 
result of a user action. This action can be for instance a specific combination of 
key on the keyboard 104, or the click of the pointing device 105 on a specific 
button, or any other similar means not further specified here, ■ 

15 • At step 1403, the command parameter ST^name is first retrieved: it corresponds 
to the name of the scalable terriplate that the scalable template instance to be 
created will abide by. This parameter ST_name is used to parse the STT table 
720 in order to find the record 721 whose "A/ame*' field 722 matches the 
Pjarameter ST^name. Once this record 721 is found, its fields "/W/n Element #" 

20 725 and "Max Element W 726 are respectively memorized as local variables 
STLmin and STLmax, Then its field ^'Description Ptf 724 is used to determine, 
according to the referenced STDT table 760, the number of meta-elements 
defined within the scalable template, and the number of cells defined within each 
element or meta-element member of the scalable template. The first number is 

25 memorized in a local variable STI_meta, and the second number is memorized in 
a local variable STI^widtli 1325 (representing the number of columns of the 
future scalable template instance). 

Then another local variable STLelement is initialised with the value taken by 
STLmin 
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table 760 is copied onto the memory location pointed by the ''Description Ptf 
field 724, 

Then control is given to step 1211. 

At step 1225, the row containing the selected cell is removed from the range of 
cells 674. 

Then the left most cell located within the range of cells 674 on the row 
representing the element defined within the edited scalable template is selected. 
Then the scalable template definition is updated by removing the deleted 
meta-element which was described by a couple (meta-element format, 
meta-element profile). 

In addition the current description of the scalable template, as illustrated by the 
range of cells 674, as recorded in the working buffer, and following the STDT 
table 760 is copied onto the memory location pointed by the Description. Ptf' 
field 724. 

Then control is given to step 1227. 

At step 1226, the cun-ent cell within the "Editor Space" sheet 675 is respectively 
moved up or down if the spreadsheet user has clicked with the pointing device 
105 on the "Up" push-button 679, or on the "Down" push-button 680, and also if 
this rnovement does not move the current cell away from the range of. cells 674 
illustrating the scalable template. 

At step 1227, the local variables STEJormat and STE^profile are respectively 
set equal to the name of the element format or meta-element fomiat and to the 
name of the element profile or meta-element profile corresponding to either the 
element or the meta-element illustrated by to the currently selected cell within the 
range of cells 674. Then control is given to step 121 1 . 

At step 1228, the Scalable Template Editor Dialog Box 661 is closed so that it 
disappears from the display device 106, then the "Editor Space" sheet 675 is 
removed from the window 160 so that it is replaced by the original sheet present 
at Element Profile Editor invocation time. All the means which were temporarily 
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the spirit of the invention. Once the user has acknowledged this notification 
message through conventional means such as clicking with the pointing device 
105 on an "OK" push-button present within a warning message pop-up window, 
or any other similar means without departing from the spirit of the invention, 
control is given to step 121 1 . 

At step 1222, the local variable STE^min is either incremented or decremented 
by 1 (one) according to the direction (up or down) specified by the pointing 
device 105 on the spin button 667, and as long as Its value remains positive and 
less than or equal to both an upper limit set equal to 254 in a preferred 
embodiment of the present invention and to the value shown in the text box 669. 
Then control is given to step 1 21 1 . 

At step 1223, the local variable STE_max is either incremented or decremented 
by 1 (one) according to the direction (up or down) specified by the pointing 
device 105 on the spin button 668, and as long as its value remains positive, 
greater than the value shown in the text box 666 and less than or equal to an 
upper limit set equal to 254 in a preferred embodiment of the pi-esent invention. 
Then control is given to step 1 21 1 . 

At step 1224, a new row is Inserted in the range of cells 674 illustriating the edited 
scalable template, above the row where the last selected cell was previously 
located. 

Then the left most cell located on the new row within the range of cells 674 is 
selected. 

Then the scalable template definition is updated In the working buffer by 
introducing a new meta-element which is described, like the other ones, by a 
couple (meta-element formal 765, meta-element profile 764) which defaults to a 
couple of default fomiat and default profile, which are also respectively assigned 
to the local variable STEJormat and STE^profile, 

In addition the current description of the scalable template, as illustrated by the 
range of cells 674, as recorded in the wori<ing buffer, and following the STDT 
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• the "Namef field 722 is set to the value found in the text box 665 and 
validated at step 1219; 

• the ''Last Change Dat^ field 723 is set to the system time reference, as 
known by the central processor 1 01 ; 

5 • the ''Description Ptf field 724 is set to the memory location which has just 
been allocated ; 

• the "M/7 Element field 725 is set to the value of the local variable STE_min\ 

• the "/Wax Element iP field 726 is set to the value of the local variable 
STE_max] and 

10 • the "Type" field 727 is set as follows: the attribute "meta" 728 is set equal to 
"no", and the attribute "referenced" 719 is set to "none". 
In addition the current description of the scalable template, as illustrated by the 
range of cells 674, as recorded in the worthing buffer, and following the STDT 
table 760 is copied onto the memory location pointed by the "Description Ptf 

15 field 724. For each element fomiat name or meta-element fomriat name found in 
the column 765 of this STDT table 760, the EFT table 700 is visited to identify 
the corresponding record 701 whose "A/ame^ field 702 matches this element or 
meta-element. fomiat name. Once found, the "referenced" attribute 709 of the 
"Typ^ field 707 of this record 701 is set to the value template if and only if its 

20 former value was equal to none. For each element profile name or meta-element 
profile name found in the column 764 of this STDT table 760, the EPT table 710 
is visited to identify the corresponding record 711 whose "A/ame" field 712 
matches this element or meta-element profile name. Once found, the 
"referenced" attribute 719 of the "Type" field 717 of this record 711 is set to the • 

25 value template if and only if its fomier value was equal to none. Then control is 
given to step 1211. 

• At step 1221 , a warning message notification is issued for informing the user that 
a valid and unique name must be specified in the text box 665 prior to clicking on 
the "Save As" push-button 672. This can typically be done by displaying on the 
30 display device 106 a warning message in a pop-up window, or in a status bar 
area, but any other similar means could be used Instead, without departing from 
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"referenced" attribute 719 of the "Type^ field 717 of this record 711 is set to the 
value TEMPLATE If and only if its fonner value was equal to none. Then control is 
given to step 1211. 

At step 1218, a warning message notification is issued for informing the user that 
the edited scalable template is already referenced by an existing scalable 
template instance. This can typically be done, by displaying on the display device 
106 a warning message in a pop-up window, or in a status bar area, but any 
other similar means could be used instead, without departing from the spirit of 
the invention. Then the user is prompted to either cancel the cun^ent "Save" 
operation, or to pursue it. This can typically be done by displaying on the display 
device 106 a prompting message in a pop-up window, but any other similar 
means could be used instead, without departing from the spirit of the invention. 
Once the user has made his choice through conventional means such as clicking 
with the pointing device 105 on an "Cancel" or "Continue" push-button present 
within a prompting message pop-up window, or any other similar means without 
departing from the spirit of the invention, control is given to step 1211 if the 
spreadsheet user decision is to cancel the opei'ation, or to step 1217 if the 
spreadsheet user decision is to continue the operation. 

At step 1219, a test is perfomied on the value found in the text box 665 to 
determine if it corresponds to a valid new name. The corresponding criteria are 
implementation dependent and may take different fomis without departing from 
the spirit of the invention, as long as the new proposed name is a unique 
character string against all the already defined names recorded in the "A/ame^ 
fields 702, 712, and 722. If validity and uniqueness are proven, then control is 
given to step 1220; othenA/ise control is given to step 1221. 

At step 1220, memory space is allocated within the main memory 102 to later 
record the descriptor of the scalable template. This allocated memory is part of 
the memory space corresponding to the currently opened electronic spreadsheet 
file. Then a new record 721 is created in the STT table 720, and this new record 
721 is initialised as follows: 
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selected cell within the range of cells 674. Then the local variable STEjprofile is 
also set equal to the name found in the text box 670. Then control is given to 
step 1211. 

• At step 1216, a test is perfomied to check if the currently edited scalable 
S template is already referenced by an existing scalable template instance. For this 

purpose is considered the value of the "referenced" attribute 729 within the 
"Type^ field 727 of the record 721 within the STT table 720 whose "A/ame" field 
722 is equal to the local variable STE_name. If the value of this attribute is found 
equal to "none", then control is given to step 1217; otherwise cpntrol is given to 
10 step 1218. 

• At step 1217, the STT table 720 is updated by refreshing the record 721 whose 
"A/ame^' field 722 is equal to the local variable STE.name. For this piirpose, 

. • the "Lasf Change Dat^ field 723 is set to the system time , reference, as 
known by the central processor 101 ; 
15 • the "M/n Element r field 725 is set to the value of the local variable STE^niin; 

• the "Max Element ff* field 726 is. set to the value of the local variable 
$TE_max. 

In addition the current description of the scalabfe template, as illustrated by the 
20 . range of cells 674, as recorded in the working buffer, and following the STDT 
table 760 is copied onto the memory, location pointed by the "Description Ptf 
field 724. For each element format name or meta-^element fomnat name found in 
the column 765 of this STDT table 760, the EFT table 700 is visited to identify 
the corresponding record 701 whose "A/ame^ field 702 matches this element or 
25 meta-element format name. Once found, the "referenced" attribute 709 of the 
"Type^' field 707 of this record 701 is set to the value template if and only if its 
fomier value was equal to none. For each element profile name or meta-element 
profile name found in the column 764 of this STDT table 760, the EPT table 710 
is visited to identify the corresponding record 711 whose "A/ame" field 712 
30. matches this element or meta-element profile name. Once found, the 
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• If the user action is a clicl< on the push-button "Save" 673, then control is 
given to step 1216; 

• if the user action is a click on the push-button "Save As" 672, then control is 
given to step 1219; 

S • if the user action is a click on the push-button ''Add" 677, then control is given 
to step 1224; 

• if the user action is a click on the push-button "Delete" 678, then control is 
given to step 1225; 

• if the user action is a click on the push-button "Up" 679 or on the push-button 
10 "Down" 680, then control is given to step 1226; 

• if the user action is an update of the combo box 671, then control is given to 
step 1214; 

• if the user action is an update of the combo box 670, then control is given to 
step 1215; 

15 • if the user action is a click on the spin button 667, then control is given to step 
1222; 

• if the user action is a click on the spin button 668, then control is given to step 
1223; 

• if the user action is a click on the push-button "Done" 663, or on the 
20 closing-window push-button 662, then control is given to step 1228. 

• At step 1214, the scalable template description is updated in the working buffer 
by replacing by the element fonnat or meta-element fomiat narhe found in the 
text box 671 the previous element fomiat or meta-element format specification 
corresponding to the element or meta-element illustrated by the currently 

25 selected cell within the range of cells 674. Then the local variable STE_format is 
also set equal to the name found in the text box 671 . Then control is given to 
step 1211. 

• At step 1215, the scalable template description is updated in the working buffer 
by replacing by the element profile or meta-element profile name found in the 

30 text box 670 the previous element profile or meta-element profile specification 
corresponding to the element or meta-element illustrated by the currently 
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Finally the local variable STEjprofile Is filled with the name of the element profile 
or of the meta-element profile corresponding to the row where Is located the 
currently selected cell within the range of cells 674. . 

• At step 1211, the Scalable Template Editor Dialog Box 661 is displayed on the 
5 display device 106. 

The label box 664 is initialised with the value of the local variable STE^nams. 
The text box 666 is filled with the value of the local variable STE_min. 
The text box 669 is filled with the value of the local variable STE_max, 
The combo box 671 is filled with the value of the local variable STEJormat 

10 The combo box 670 is filled with the value of the local variable STEjprofile. 

Then the range of cells 674 is updated according to the description recorded in 
the memory clipboard: the content of the clipboard is pasted on this blank sheet 
at a fixed cell address 674 (address B2 in a preferred embodiment of. the present . 
invention, as shown on FIG 6D), so that the user can visualise on the display 

IS device 106, within the window 660 an illustration of the scalable template. 

Then a test is perfonned to check if all the element fonmats, element profiles, 
meta-element formats and meta-elements profiles contributing to the scalable 
template definition illustrated by the range of cells 674, have the same number of 
fields. If it is the case, then the two push-buttons "Sav^' 673 and "iSave AsT 672 

20 are enabled, so that the click with the pointing device 105 on one of these two 
push-buttons is recognised as a valid event. Othenwise the two push-buttons 
"Save" 673 and "Save A^' 672 are disabled, so that the click with the pointing 
device 105 on one of these two push-buttons is not recognised as a valid event. 

• At step 1212, the method is waiting for any user action on the Scalable Template 
25 Editor Dialog Box 661 . Such user action is typically resulting from a click with the 

pointing device 105, but take other similar fomns such as, but not limited to a 
specific combination of key on the keyboard 104, or any other similar means not 
further specified here. 

• At step 1213, a user action on the Scalable Template Editor Dialog Box 661 Is 
30 detected. 
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Then memory space is allocated within the main memory 102 to later record the 
Illustrative range of cells for the new scalable template. This allocated memory is 
part of the memory space corresponding to the currently opened electronic 
spreadsheet file and follows the STDT table 760 illustrated in FIG 7E. Then a 
new record 721 Is created in the STT table 720, and this new record 721 is 
initialised as follows: 

• the "NameT field 722 Is set to the value of the local variable STE_name ; 

• the ''Last Change Datef* field 723 is set to the system time reference, as 
known by the central processor 101 ; 

• the "Description Ptf field 724 is set to the memory location which has just 
been allocated ; 

• the "Mn Element if field 725 is set to the value of the local variable STE^min] 

• the "Max Element iF field 726 is set to the value of the local variable 
STE_max ; and 

• the "Type" field 727 is set as follows: the attribute "meta" 728 is set equal ta 
"no", and the attribute "referenced" 729 is set Jo "none". 

Then a working buffer is allocated in main memory 102 and initialised with a 
default scalable template description which corresponds to a single pair 762 of 
default element format and default element profile. This default scalable template 
description is then used to build on the clipboard within the main memory 102 a 
spreadsheet range of cells illustrating the new scalable template. This 
construction is achieved as explained at the end of the step 1208. Then control is 
given to step 1210. 

At step 1210, the "Editor Space" sheet 675 is made the cun^ent sheet and this 
sheet is turned to write-protect mode while regular row insertion and deletion are 
disabled. 

Then the top left cell of the range of cells 674 is selected. 
Then the local variable STE^fonvat is filled with the name of the element format 
or of the meta-element format corresponding to the row where is located the 
currently selected cell within the range of cells 674. 
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• At Step 1207, an exception handler is invoked to treat this "should not occur^ 
condition. Such operation is implementation dependent and can take different 
forms such as the display on the display device 106 of an enror message pop-up 
window. Then control is given to step 1228. 

5 • • At step 1208, 

• the local variable STE_min is set to the value found in the "Min Element #" 
field 725 of the record 721 found at step 1206, 

• the local variable STEjmax is set to the valuie found in the "Max Element #" 
field 726 of the record 721 found at step 1206. 

10 . Then the memory location pointed by the Description Ptr field 724 of the record 
721 found at step 1206 (where is recorded the description of the scalable 
\ V template according to the STDT table 760 illustrated in FIG 7E) is copied in a 
. working buffer which in tums follows the same STDT table 760; 
This structure is then used to build on the clipboard within the main memory 102 
IS a spreadsheet range of cells illustrating the scalable template definition copied in 
. the working buffer. 

. This construction is achieved by loadirig in the clipboard within the main memory 
. . 102 an ordered sequence of ranges of cells, each of them successively abiding 
by the fomriat (column 765) and the profile (column 764) definition corresponding 
20 to each pair of fomnat and profile names, starting with the first pair 761 up to the 
last one 763. 

Then control is given to step 1210. 

* At step 1209, a new name for the newly created scalable template is determined, 
according to a name string taking in a preferred embodiment of the present. 

25 invention the form "New XX^ where XX corresponds to a counter value ensuring . 
the name uniqueness with respect to all the names previously defined and 
recorded in the "A/ame^* fields 702, 712 and 722 found in the respective records 
701, 711 and 721 of the respective tables EFT 700; EPT 710 and STT 720. Any 
other similar conventional means could be used Instead without departing from 

30 the spirit of the invention, as long as the uniqueness of the newly created name 
is ensured. Then the new name is recorded in the local variable STE^name. 
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The method for creating or updating scalable templates used in the preferred 
embodiment of the present invention is summarised In flowchart 1200 of FIG 12. 
This method can be seen as the processing of the Scalable Template Editor 
command. 

S • At step 1201 , the method is in its default state, waiting for an event to Initiate the 
process. 

• At step 1202, the Scalable Template £cf/tor command is detected, as a result of 
an user action. This action can be for instance: 

• aspecificcombinationof key on the keyboard 104, or 

. 10 • the click of the pointing device 105 on a specific button, or . 

• any other similar means not further specified here. 

• • At step 1203, the parameter of the command is retrieved. It corresponds to a 
mandatory parameter STE_name which can either take a reserved value "new" or 
another value corresponding to a character string name, as found in the "A/ame^ 
15 field 732 of a record 731 within the STMT table 730. This parameter is recorded 
. , as a local variable. 

• At step 1204, some local variables are initialised: the local variable STE_min Is 
set to the default value 1 (one), the local variable STE_max is set to the default 
value 255. 

20 • At step 1205, a test is perfonmed to detenmine the value taken by the local 
variable STE^name. If found equal to "new", then control is given to step 1209; . 
othen/vise control Is given to step 1206. 

• At step 1206, the STT table 720 is looked up to locate a record 721 whose 
"A/ame" field 722 is found equal to the value taken by the local variable 

25 STE^name. If such a record is found, then control is given to step 1208; 
othenwise control is given to step 1207. 
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• the ''Last Change DateT field 713 is set to the system time reference, as known 
by the central processor 101 ; 

• the "Description Ptf field 714 is set to the memory location which has just 
been allocated; 

S • the ''Row if* field 715 is set to the value 1 (as in the preferred embodiment of 
the present invention the scalable templates are managed in a 2D 
environment; this field would cany the number of defined rows for the created 
profile in a 3D environment); 

• the ''Column field 716 is set to the value of the local variable EPE_size\ 

10 • the "Type" field 717 is set as follows: the attribute "meta" 718 is set equal to the 
value of the local variable EPE^meta, and the attribute "referenced" 719 is set 
to "none". 

Then control is given to step 1013. 

• At step 1024, a warning message notification is issued for informing the user that 
15 a valid and unique name must be specified in the text box 645 prior to clicking on 

the "Save As" push-button 651. This can typically be done by displaying on the 
display device 106 a warning message in. a pop-up window, or in a status bar 
area, but any other similar means could be used instead, without departing from 
the spirit of the invention. Once the user has acknowledged this notification 
20 message through conventional means such as clicking with the pointing device 
105 on an "OK" push-button present within a waming message pop-up window, 
or any . other similar means without departing from the spirit of the invention, 
control is given to step 1013. 

• At step 1025, the Element Profile Editor Dialog Box 641 is closed so that it 
25 disappears from the display device 106, then the "Editor Space" sheet 655 is 

removed from the window 160 so that it is replaced by the original sheet present 
at Element Profile Editor invocation time. Finally control is given back to the 
initial step 1001 for processing any future Element Profile Editor command. 

E4. Scalable Template Editor method 
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""Nam^ fields 702, 712, and 722. If validity and uniqueness are proven, then 
control is given to step 1023; othenA^ise control is given to step 1024. 

• At step 1019, the default attributes currently defined in the spreadsheet 
environment are applied to the ''Editor Space" sheet 655, so that the displayed 

5 illustration of the element profile or meta-element profile receives these same 
default attributes. Then control is given to the step 1013. 

• At step 1020, the local variable EPEjsize is either incremented or decremented 
by 1 (one) according to the direction (up or down) specified by the pointing 
device 105 on the spin button 647, and as long as it value remains positive and 

10 less than or equal to an upper limit set equal to 254 in a preferred embodiment of 
the present invention. Then control is given to step 1013. 

• At step 1021, the local variable EPE_meta is updated, so that its value becomes 
"yes" (respectively "no") if the bottom (respectively top) option button 650 has 
been clicked on. Then control is given to step 1013. 

15 • At step 1022, the Scalable Template Refresh Manager command is issued with 
the following parameters: EPE_name, "profile", and EPE^descJ Then the local 
variable EPE_de$c is updated with the current profile description, as riacorded in 
the memory location pointed by the ''Description Ptf field 714 and then control is 
given to step 1013. 

20 • At step 1023, memory space is allocated within the main memory 102 to later 
record the illustrative range of cells for the element profile or meta-element 
profile. This allocated memory is part of the memory space corresponding to the 
currently opened electronic spreadsheet file. Then a hew record 711 is created in 
the EPT table 710 which is saved as part of the electronic spreadsheet file, and 

25 this new record 711 is initialised as follows: 

• the 'Wame" field 712 is set to the value found in the text box 645 and validated 
at step 1018; 
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• the "Last Change Dat^ field 713 is set to the system time reference, as 
known by the central processor 101 ; 

• the "Column r field 716 is set to the value of the local variable EPE_size ; 
and 

5 • the "Typd' field 717 is set as follows: the attribute "meta" 718 is set equal to 
the value of the local variable EPE^meta. 
In addition the range of cells 654 illustrating on the "Editor Space" sheet 655 the 
current definition of the element profile or meta-element profile is copied onto the 
memory location poirited by the ""Description Ptf field 714: Then control is given 

10 to step 1022. 

• At step 1017, the EPT table 710 is updated and saved as part of the electronic 
spreadsheet file by refreshing the recprd 711 whose "Namef* field 712 is equal to 
the local variable EPE_name, For this purpose, 

• the "Last Change DateF field 713 is set to the system time reference, as 
15 known by the central processor 101 ; 

• the "Column r field 716 is set to the value of the. local variable EPE^size ; 
and 

• the "TypeT field 717 is set as follows: the attribute "meta" 718 is set equal to 
the value of the local variable EPE^meta. 

20 In addition the range of cells 654 illustrating on the "Editor Space" sheet 655 the 
. current definition of the element profile or meta-element profile is copied onto the 
memory location pointed by the "Description Ptf" field 714. 
Then the local variable EPE_desc is updated with the current profile description, 
as recorded in the memory location pointed by the Description Ptf' field 714, 

25 and control is given to step 1013. 

• At step 1018, a test is perfonmed on the value found in the text box 645 to 
detemiine if this value corresponds to a valid new name. The corresponding 
criteria are implementation dependent and may take different fomns without 
departing from the spirit of the invention, as long as the new proposed name Is a 

30 unique character string against all the already defined names recorded in the 
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• The push-buttons "Save" 652 and ""Save & Refresff 648 are disabled 
othenwise (local variable EPE_size is not found equal to the "Column #" field 
716 of the cun-ent record 711, and the attribute "referenced" 719 within the 
"Type'' field 717 of this same record 711 is not found equal to "no"), so that 
S any future click with the pointing device 105 on one of these two push-buttons 

'"SaveT 652 and "Save & RefrestT 648 will not be recognised as an event. 

• At step 1014, the method is waiting for any user action on the Element Profile 
Editor Dialog Box 641 . Such., user action is typically resulting from a click with the 
pointing device 105, but take other similar fonns such as, but not limited to a 

10 specific combination of key on the keyboard 104, or any other similar means not 
further specified here, 

• At step 1015, a user action on the Element Profile Editor Dialog Box 641 is 
detected. 

• If the user action is a click on the push-button "Save & Refresh" 648, then 
15 control is given to step 1016; 

• If the user action is a click on the push-button "Save" 652, then control is 
given to step 1017; 

• if the user action is a click on the push-button "Save As" 651, then control is. 
. given to step 1018; 

20 • if the user action is a click on the push-button . "Clear'' 649, then control is given, 
to step 1019; 

• if the user action is a click on the spin button 647, then control is given to step 
1020; 

• if the user action is a click on one of the two option buttons 650, then control is 
25 given to step 1021; 

• if the user action is a click on the push-button "Done" 643. or on the 
closjng-window push-button 642, then control is given to step 1025. 

• At step 1016, the EPT table 710 is updated and saved as part of the electronic 
spreadsheet file by refreshing the record 711 whose "A/ame?' field 712 is equal to 

30 the local variable EPE^name. For this purpose, 
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• the ''Column field 716 is set to the value of the local variable EPE_size ; 
and 

• the 'Type^' field 717 is set as follows: the attribute "meta" 718 is set equal to 
the value of the local variable EPEjneta, and the attribute "referenced" 719 

5 Is set to "none". 

Then control is given to step 1010. 

• At step 1010, a test is performed to determine the value taken by the local 
variable EPE_range. If found equal to "yes",, then control is given to step 101.1; 
othenwise control is given to step 1012. 

10 • At step 1011, the currently selected range of cells is copied onto the clipboard 
and the local variable EPE^size is set equal to the number, of columns of the 
selected range. 

• At step 1012, the "Editor Space" sheet 635 is made the current sheet and the 
content of the clipboard is pasted on this blank sheet at a fixed cell address 634 

.15 (address B2 in a prefen-ed embodiment of the present invention, as shown on 
FIG 6B), so that the user can visualise on the display device 106, within the 
window 160 an illustration of the element profile or meta-element profile. 

• At step 1013, the Element Profile Editor Dialog Box 641 is. displayed on the 
. display device 106. ' 

20 • The label box 644 is initialised with the value of the local variable EPE_name, 
The top (respectively bottom) option button 650 is filled with a black point if 
the local variable EPE^meta is found equal to "no" (respectively "yes"). 

• The text box 646 is filled with the value of the local variable EPE^size. 

• The push-buttons "Save" 652 and "Save & Refrestf 648 are enabled if the 
25 local variable EPE^sfee is found equal to the ''Column #" field 716 of the 

current record 711, or if the attribute "referenced" 719 within the "Typef' field 
717 of this same record 711 is found equal to "no", so that any future click 
with the pointing device 105 on one of these two push-buttons "Save?' 652 
and "Save & Refresif 648 will be recognised as a valid event. 
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• the local variable EPE_meta is set to the value "yes" or "no" according to the 
value of the "meta" attribute 718 within the "Type^ field 717 of the record 711 
found at step 1006, 

• the local variable EPE_$ize is set to the value found in the ""Column #" field 
5 71 6 of the record 71 1 found at step 1 006, and 

• the memory location pointed by the "Description Ptf field 714 of the record 
711 found at step 1006 is copied onto the clipboard and within the local 
variable EPE^Desc. 

Then control is given to step 1012. 

10 • At step 1009, a new name for the newly created profile is detennined, according 
to a name string taking in a preferred embodiment of the present invention the 
fomn "New XX" where XX corresponds to a counter value ensuring the name 
uniqueness with respect to all the names previously defined and recorded in the 
"A/ame" fields 702, 712 and 722 found in the respective records 701, 711 and 

15 721 of the respective tables EFT 700, EPT 710 and STT 720. Any other similar 
conventional means could be used instead without departing from the spirit of the 
invention, as long as the uniqueness of the newly created name is ensured. 
Then the new name is recorded in the local variable EPEjname, 
Then memory space is allocated within the main memory 102 to later record the 

20 illustrative range of cells for the element profile or meta-eiement profile. This 
allocated memory is part of the memory space corresponding to the curently 
opened electronic spreadsheet file. Then a new record 711 is created in the EPT 
table 710, and this new record 711 is initialised as follows: 

• the "Nam^ field 71 2 is set to the value of the local variable EPE_name ; 

25 • the ""Last Change Dat^ field 713 is set to the system time reference, as 
known by the central processor 101 ; 

• the Description Ptf field 714 is set to the memory location which has just 
been allocated ; 

• the ''Row if field 715 is set to the value 1 (as in the preferred embodiment of 
30 the present invention the scalable templates are managed in a 2D 

environment; this field would cany the number of defined rows for the created 
profile in a 3D environment) ; 
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• At Step 1002, the Element Profile Editor command is detected, as a result of an 
user action. Tliis action can be for instance: 

• a specific combination of key on the l<eyboard 104, or 

• the click of the pointing device 105 on a specific button, or 
5 • any other similar means not further specified here. 

• At step 1003, the parameters of the command are retrieved. They con^espond to: 

• a first mandatory parameter EPE^name which can either take a reserved 
value "new" or another value con-esponding to a character string name, as 
found in the "Namd' field 732 of a record 731 within the STMT table 730; and 

10 • a second optional parameter EPE_range which can take only two predefined 
values "yes" and "no". This second optional parameter must be present when 
the first mandatory parameter value differs from the "new". 
These two parameters are recorded as local variables. . 

• At step 1004, some local variables are initialised: the local variable EPE_meta is 
15 set to the value "no", the local variable EPE^size is set to the value 8 (eight). 

• At step 1005, a te$t is performed to detemnine the value taken by the local 
variable EPE_name. If found equal to "new", then control is given to step 1009; 
othenA/ise control is given to step 1006. 

. • At step 1006, the EPT table 710 is looked up to locate a record 711 whose 
20 "A/am^' field 712 is found equal to the value taken by the local variable 
EPE^name, If such a record is found, then control is given to step 1008; 
othenwise control is given to step 1007. 

• At step 1007, an exception handler is invoked to treat this "should not occur" 
condition. Such operation is implementation dependent and can take different 

25 fomns such as the display on the display device 106 of an eror message pop-up 
window. Then control is given to step 1025. 

• At step 1008, 
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• the "Type'' field 707 is set as follows: the attribute "meta" 708 is set equal to 
the value of the local variable EFE_meta, and the attribute "referenced" 709 
is set to ''none". 

Then control is given to step 913. 

5 • At step 924, a warning message notification is issued for informihg the user that 
a valid and unique name must be specified in the text box 625 prior to clicldng on 
the ''Save As" push-button 631. This can typically be done by displaying on the 
display device 106 a warning message In a pop-up window, or iii a status bar 
area, but any other similar means could be used instead, without departing from 

10 the spirit of the invention. Once the user has acknowledged this notification 
message through conventional means such as clicking with the pointing device 
105 on an "OK" push-button present within a warning message pop-up window, 
or any other similar means without departing from the spirit of the invention, 
control is given to step 913. 

15 • At step 925, the Element Format Editor Dialog Box 661 is closed so that it 
disappears from the display device 106, then the "Editor Space" sheet 675 is 
removed from the window 160 so that it is replaced by the original sheet present 
at Element Format Editor invocation time. Finally control Is given back to the 
initial step 901 for processing any future Elemertt Format Editor command. 

20 E3. Element Profile Editor method 

The method for creating or updating element profiles or meta-element profiles used 
in the preferred embodiment of the present invention is summarised in flowchart 
1000 of FIG 10. This method can be seen as the processing of the Element Profile 
£cf/f or command. 

25 • At step 1001 , the method is in its default state, waiting for an event to initiate the 
process. 
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At Step 920, the local variable EFE_size Is either incremented or decremented by 
1 (one) according to the direction (up or down) specified by the pointing device 
105 on the spin button 627, and as long as it value remains positive and less 
than or equal to an upper limit set equal to 254 in a pretended embodiment of the 
present invention. Then control is given to step 913. 

At step 921, the local variable EFE_meta is updated, so that its value becomes 
"yes" (respectively "no") if the bottom (respectively top) option button 630 has 
been clicked on. Then control is given to step 913. 

At step 922, the Scalable Template Refresh Manager command is issued with 
the following parameters: EFE_name, "format" and then control is given to step 
913. 

At step 923, mjBmory space is allocated within the main memory 102 to later 
record the illustrative range! of cells for the iaiement format or meta-element 
fonnat. This allocated memory is part of the memory space corresponding to the 
currently opened electronic spreadsheet file. Then a new record 701 is created in 
the EFT table 700 which is saved as part of the efectronic spreadsheet file, and 
this new record 701 is initialised as follows: 

. • the "Warned field 702 is set to the value; found in the text box 625 and 
. validated at step 918; 

• the "Last Change Date'' field 703 is set to the system time reference, as 
l<nown by the central processor 101 ; 

• the "Description Ptf field 704 is set to the memory location which has just 
been allocated ; 

• the ""Row field 705 is set to the value 1 (as in the preferred embodiment of 
the present invention the scalable templates are managed in a 2D 
environment; this field would cany the number of defined rowis for the created 
fomiat in a 3D environment) ; 

• the ""Column field 706 is set to the value of the local variable EFE_size ; 
and 
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• the "Type" field 707 is set as follows: the attribute "meta" 708 is set equal to 
the value of the local variable EFE_meta, 

In addition the range of cells 634 illustrating on the ''Editor Space" sheet 635 the 
current definition of the element format or meta-element format is copied onto 
5 the memory location pointed by the ""Description Ptf field 704. Then control is 
given to step 922. 

• At step 917, the EFT table 700 is updated and saved as part of the electronic 
spreadsheet file by refreshing the record 701 whose "Namef' field 702 is equal to 
the local variable EFE_name, For this purpose, 

10 • the "Last Change Dat^ field 703 is set to the system time reference, as 
known by the central processor 101 ; 

• the "Column iP field 706 is set to the value of the local variable EFE_size ; 
and 

• the "Type" field 707 is set as follows: the. attribute "meta" 708 is set equal to 
15 the value of the local variable EFE^meta. 

In addition the range of cells 634 illustrating on the "Editor Space" sheet 635 the 
current definition of the element format or meta-element format is copied onto 
the memory location pointed by the "Description Ptf field 704. Then control is 
given to step 913. 

20 . • At step 918, a test is perfonned on the value found in the text box 625 to 
detemnine if it corresponds to a valid new name. The corresponding criteria are 
implementation dependent and may take different forms without departing from 
the spirit of the invention, as long as the new proposed name is a unique 
character string against all the already defined names recorded in the "A/ame" 

25 fields 702, 712, and 722. If validity and uniqueness are proven, then control is 
given to step 923; othenwise control is given to step 924. 

• At step 919, the default attributes currently defined in the spreadsheet 
environment are applied to the "Editor Space" sheet 635, so that the displayed 
illustration of the element fomiat or meta-element format receives these same 

30 default attributes. Then control is given to the step 913. 
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any future click with the pointing device 105 on one of these two push-buttons 
""Say^ 632 and "Save & Refrestf 628 will not be recognised as an event. 

• At step 914, the method is waiting for any user action on the Element Format 
Editor Dialog Box 621. Such user action is typically resulting from a click with the 

5 pointing device 105, but take other similar fomis such as, but not limited to a 
sspecific combination of key on the keyboard 104, or any other similar means not 
further specified here. 

• At step 915, a user action on the Element Format Editor. Dialog Box 621 is 
detected. 

10 • If the user action is a click on the push-button "Save & Refresh" 628, then 
control is given to step 916; 

• if the user action is a click on the pushybutton "Save" 632, then control is 
given to step 917; 

• if the user action is a click on the push-button "Save As" 631, then control is 
15 given to step 918; 

• if the user action is a click on the push-button "Clear" 629!, then control is given 
to step 919; 

• if the user action is a click on the spin button 627, then . control, is given to step 
920; 

20 • if the user action is a click on one of the two option buttons 630, then control is 
given to step 921 ; 

• if the user action is a click on the push-button "Done" 623, or on the 
closing-window push-button 622, then control is given to step 925. . 

• At step 916, the EFT table 700 is updated and saved as part oif the electronic 
25 spreadsheet file by refreshing the record 701 whose "A/ame^ field 702 is equal to 

the local variable EFE_name. For this purpose, 

• the "Lasf Change DateP field 703 is set to the system time reference, as 
known by the central processor 101 ; 

• the "Column #" field 706 is set to the value of the local variable EFE^size ; 
30 and 
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Then control is given to step 910. 

• At step 91 0, a test is performed to detemnine the value taken by the local variable 
BFE_range. If found equal to "yes", then control is given to step 911; othenA^ise 
control Is given to step 912. 

S • At step 91 1 , the currently selected range of cells is copied onto the clipboard and 
the local variable EFE_size is set equal to the number of columns of the selected 
range. 

• At step 912, the "Editor Space" sheet 635 is made the current sheet and the 
content of the clipboard is pasted on this blank sheet at a fixed cell address 634 

10 (address B2 in a preferred embodiment of the present invention, as shown on 
FIG 6B), so that the user can. visualise on the display device 106, within the 
window 160 an illustration of the element format or meta-element fonnat. 

• At step 913, the Element Format Editor Dialog Box 621 is displayed on the 
display device 106. 

15 • The label box 624 is initialised with the value of the local variable EFE_name. 

• The top (respectively bottom) option button 630 is filled with a black point if 
the local variable EFE_meta is found equal to "no" (respectively "yes"). 

• The text box 626 is filled with the value of the local variable EFE_size. 

• The push-buttons "Save^ 632 and "Save & Refrestf 628 are enabled if the 
20 local variable EFE^size is found equal to the "Column field 706 of the 

cun-ent record 701, or if the attribute "referenced" 709 within the "Typd" field 
707 of this same record 701 is found equal to "no", so that any future click 
with the pointing device 105 on one of these two push-buttons "Save^' 632 
and "Save & Refresh' 628 will be recognised as a valid event. 
25 • The push-buttons "Save'' 632 and "Save & Refresh' 628 are disabled 
othenvise (local variable EFE^size is not found equal to the "Column field 
706 of the current record 701, and the attribute "referenced" 709 within the 
"Typ^ field 707 of this same record 701 is not found equal to "no"), so that 



157 



wo 03/014987 



• the memory location pointed by the "Description Ptf field 704 of the record 
701 found at step 906 is copied onto the clipboard. 

Then control is given to step 912. 

• At step 909, a new name for the newly created format is detemnined, according 
5 to a name string taking in a preferred embodiment of the present invention the 
fonm "New XX" where XX corresponds to a counter value ensuring the name 
uniqueness with respect to all the names previously defined and recorded in the 
"A/ame" fields 702, 712 and 722 found in the. respective records 701, 711 and 
721 of the respective tables EFT 700, EPT 710 and STT 720, Any other similar 
10 conventional means could be used instead without departing. from the spirit of the 
invention, as long as the uniqueness of the newly created name is ensured. 
Then the new name is recorded in the local variable EFE_name. Then memory 
space is allocated within the main memory 102 to later record the illustrative, 
range of cells for the element format or rneta-element format. This allocated 
15 memory is part of the memory space corresponding to the currently opened 
electronic spreadsheet file. 

Then a new record 701 is created in the EFT table 700, and this hew record 701 
is initialised as follows: 

• the "A/a/ne" field 702 is set to the value of the local variable EFE_name ; . 

20 • the "Last Change Dat^ field 703 iis set to the system time reference, as 
known by the central processor 101 ; 

• the "Description Ptf field 704 is set to the memory location which has just . 
been allocated ; 

• the ''Row field 705 is set to the value 1 (as in the preferred embodiment of 
25 the present invention the scalable templates are managed in a 2D 

environment/this field would carry the number of defined rows for the created 
fonmat in a 3D environment) ; 

• the ''Column #' field 706 is set to the value of the local variable EFE_size ; 
and 

30 • the "Type" field 707 is set as follows: the attribute "meta" 708 is set equal to 
the value of the local variable EFE^meta, and the attribute "referenced" 709 
Is set to "none". 
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• At Step 903. the parameters of the command are retrieved. They correspond to: 

• a first mandatory parameter EFE^name which can either take a reserved 
value "new" or another value corresponding to a character string name, as 
found in the "A/ame?* field 732 of a record 731 within the STMT table 730; and 

5 • a second optional parameter EFE^range which can take only two predefined 
values Ves" and "no". This second optional parameter must be present when 
the first mandatory parameter value differs from the "new". 
These two parameters are recorded as local variables. 

• At step 904, some local variables are initialised: the local variable EFE_meta is 
10 set to the value "no", the local variable EFE_$ize is set to the value 8 (eight). 

• At step 905, a test is perfonmed to detemnine the value taken by the local variable 
EFE^nanie, If found equal to "new", then control is given to step 909;. othenwise 
control is. given to step 906. 

• At step 906, the EFT table 700 is looked up to locate a record 701 whose " A/ame" 
IS field 702 is found equal to the value taken by the local variable EFE_name. If 

such a record is found, then control is given to step 908; othenA/ise control is 
given to step 907. 

• At step 907, an exception handler is invoked to treat this "should not occur" 
condition. Such operation is implementation dependent and can take different 

20 fonns such, as the display on the display device 106 of an error message pop-up 
window. Then control is given to step 925. 

• At step 908, 

• the local variable EFE^meta is set to the value "yes" or "no" according to the 
value of the "meta" attribute 708 within the "Typ^' field 707 of the record 701 

25 found at step 906, 

• the local variable EFE_size is set to the value found in the ""Column #" field 
706 of the record 701 found at step 906, and 
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initial step 801 for processing any future Scalable Template Manager 
command. 

• At step 835, a waming message notification is issued for infomiing the user that 
at least one selected object to be deleted is referenced by another object. This 

S can typically be done by displaying on the display device 106 a warning message 
in a pop-up window, or in a status bar area, but any other similar means could be 
used instead, without departing from the spirit of the invention. Then the user is 
prompted to either cancel the current "Delete" operation, or to pursue it. This can 
typically be done by displaying on the display device 106 a prompting message 

10 in a pop-up window, but any other similar means could be used instead, without 
departing from the spirit of the invention. Once the user has made his choice 
through conventional means such as clicking with the pointing device 105 on an 
"Cancel" or "Continue" push-button present within a prompting message pop-up 
window, or any other similar means without departing from the spirit of the 

15 invention, control is given to step 805 if the spreadsheet user decision is to 
cancel the "Delete" operation, or to step 809 if the spreadsheet user decision is 
to continue the "Delete" operation. 

E2. Element Format Editor method 

The method for creating or updating element fomiats oi^ meta-elemerit fprmjats used . 
20 in the preferred embodirrient of the present invention is summarised in flowchart 900 
of FIG 9. This method can be seen as the processing of the Element Format Editor \ 
command. 

• At step 901, the method is in its default state, waiting for an event to initiate the 
process. 

25 • At step 902, the Element Format Editor command is detected, as a result of an 
user action. This action can be for instance: 

• a specific combination of key on the keyboard 104, or 

• the click of the pointing device 105 on a specific button, or 

• any other similar means not further specified here. 
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message through conventional means such as clicking with the pointing device 
105 on an "OK" push-button present within a warning message pop-up window, 
or any other similar means without departing from the spirit of the invention, 
control is given to step 805. 

5 • At step 830, a test is perfomned to dQtermine If the local variable STM^select is 
equal to 1 (one). If it is the case, then control is given to step 831; othenA/ise 
control is given to step 829. . 

• At step 831 , a test is perfomned to detenmine the nature of the selected object, as 
specified by the "Type" field 737 "nature" attribute 741 of the corresponding 

10 record 731 of the STMT table 730. If found equal to ^Vemplate", then control is 
given to step 832; othenA^ise control is given to step 833. 

• At step 832, the Scalable Template Instanciator command is issued with 
passing one parameter equal to the "Nam^ field 732 of the unique record 731 of 
the STMT table 730 whose "Type^' field 737 has the "selected" attribute 742 

15 equal to "yes", and then control is given to step 834. 

• At step 833, a warning message notification is issued for infomiing the user that 
a single scalable template object must be selected within the Scalable Template 
Manager Dialog Box (thanks to check boxes like 612) prior clicking on the 
"Instahciate" push-button 604. This can typically be done by displaying on the 

20 display device 106 a warning message in a pop-up window, or in a status bar 
area, but any other similar means could be used instead, without departing from 
the spirit of the invention. Once the user has acknowledged this notification 
message through conventional means such as clicking with the pointing device 
105 on an "OK" push-button present within a warning message pop-up window, 

25 or any other similar means without departing from the spirit of the invention, 
control is given to step 805. 

• At step 834, the Scalable Template Manager Dialog Box 600 is closed so that it 
disappears from the display device 106 and then control Is given back to the 
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• At step 824, a test is performed to determine if the local variable STM^select Is 
equal to 1 (one). If it is the case, then control is given to step 825; othenA^ise 
control is given to step 829. 

• At step 825, a test is perfomied to determine the nature of the selected object, as 
5 specified by the "Type^ field 737 "nature" attribute 741 of the con^esponding 

record 731 of the STMT table 730. 

• If found equal to "formal, then control is given to step 826; 

• if found equal to "profile", then control is given to step:827; 

• if found equal to 'Vemplate", then control is given to step 828. 

10 - At step 826. the Element Profile Editor command is issued with passing one 
parameter equal to the "Namef* field 732 of the unique record 731 of the STMT: 
table 730 whose "Type^' field 737 has the "selected" attribute 742 equal to "yes", 
and then control is given to step 834. 

• At step 827, the Element Format Editor command is issued with passing one 
15 parameter equal to the "Nam^ field 732 of the unique record 731 of the STMT 

table 730 whose "Type^' field 737 has the "selected" attribute 742 equal to 'Ves", 
and then control is given to step 834. 

• At step 828, the Scalable Template Editor command is issued with passing one 
parameter equal to the "A/ame?' field 732 of the unique record 731 of the STMT 

20 table 730 whose "Type/' field 737 has the "selected" attribute 742 equal to "yes", 
and then control is given to step 834. 

• At step 829, a warning message notification is issued for infomning the user that 
a single object must be selected within the Scalable Template Manager Dialog 
Box (thanks to check boxes like 612) prior clicking on the "Edit" push-button 611 

25 or on the "Instanciate" push-button 604. This can typically be done by displaying 
on the display device 106 a warning message in a pop-up window, or in a status 
bar area, but any other similar means could be used instead, without departing 
from the spirit of the invention. Once the user has acknowledged this notification 
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• At step 818, a test is performed to determine if the local variable STM_new is 
equal to "none". If it Is the case, then control is given to step 819; othenAfise 
control Is given to step 820. 

• At step 819, a waming message notification is issued for infomning the user that 
5 at least one option ("Fomiaf option button 617, or "Profile" option button 609, or 

Template" option button 616) must be selected prior clicking on the "Create 
New" push-button 610. This can typically be done by displaying on the display 
device 106 a waming message in a pop-up window, or in a status bar area, but 
any other similar means could be used instead, without departing from the spirit 
10 of the invention. Once the user has acknowledged this notification message 
through conventional means such as clicking with the pointing device 105 on an 
"OK" push-button present within a waming message pop-up window, or any other 
similar means without departing from the spirit of the invention, control is given to 
step 805. 

15. • At step 820, a test is perfomned to detemriine the value taken by the Ipcal variable 
STM_n0W. 

• If found equal to "format", then control Is given to step 821; 

• If found equal to "profile", then control is given to step 822; 

• If found equal to Template", then control is given to step 823; 

20 • At step 821, the Element Format Editor command is issued with passing two 
parameters ("new" ; STM_range) and then control is given to step 834. 

• At step 822, the Element Profile Editor command is issued with passing two 
parameters ("new" ; STM^range) and then control is given to step 834. 

• At step 823, the Scalable Template Editor command is issued with passing one 
25 parameter ("new") and then control is given to step 834. 
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• At step 815, the local variable STM_new is updated to reflect the option button 
hit by the user with the pointing device 105. 

• If the user has clicked on the Tormaf option button 617, then the local 
variable S7M,neiv takes the value "foriwiat". 

5 • If the user has clicked on the "Profile" option button 609, then the local 
variable STMjnew take the value "profile". 

• If the user has clicked on the 'Template" option button 616, then the local 
variable take the value **template". 

Then control is given to step BOiS. 

10 • At step 816, the local variable STM_range is updated, so that its value swaps 
between *Ves" and "no". In addition, a check mark is respectively added within or 
removed from the check box 606 if it was previously absent or present in this 
same check box 606. Then control is given to step 805. 

• At step 817, the method updates the value of the "Type" field 737 of the record 
15 731 within the STMT table 730. whose "Warned field 732 is found equal to. the 

character string located within the list box .613 immediately on the. right of the 
check box on which the user has just clicked. 

If the previous value of this "Type^* field 737 had the "selected" attribute 742 
equal to *Ves", then the value update consists in turning this "selected" attribute 
20 742 to "no" ; reversibly if the previous value of the "selected" attribute 742 was 
equal to. "no", then the value update consists in turning this "selected" attribute 
742 to W. 

In the first case the local variable STM_select is decremented by 1, and in the 
second case the local variable STM_select is incremented by 1 . 
25 Furthemiore in the first case the check mark previously present in the check box 
on which the user has just clicked is removed from this check box and in the 
second case a check mari< is displayed in the check box on which the user has 
just clicked. Then control is given to sitep 805. 
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"Warned field 702, 712, and 722 matches the "Nam^ field 732 of a record 731 of 
the STMT table 730 whose Type^ field 737 has the "selected" attribute 742 
equal to "yes", as resulting from the step 817. Then the local variable STM^select 
is reset to the value 0 (zero). Then control is given to the step 804 for rebuilding 
the STMT table. 

At step 810, the Scalable Template Import Manager command is issued and 
then control is given to step 834. 

At step 811, a test is performed to determine if the local variable STM_select is 
equal to 0 (zero). 

• If it is the case, then control is given to step 813; 

• othenA^ise control is given to step 812. 

At step 812, the Scalable Template Export Manager command is issued and 
then control is given to step 834. 

At step 813, a waming message notification is issued for informing the user that 
at least one object must be selected prior clicking on the Txporf push-button 
606. This can typically be done by displaying on the display device 106 a waming 
message in a pop-up window, or in a status bar area, but any other similar 
means could be used instead, without departing from the spirit of the invention. 
Once the user has acknowledged this notification message through conventional 
means such as clicking with the pointing device 105 on an "OK" push-button 
present within a waming message pop-up window, or any other similar means 
without departing from the spirit of the invention, control is given to step 805. 

At step 814, the local variable STMJndex is either incremented or decremented 
by 1 (one) according to the direction (up or down) specified by the pointing 
device 105 on the scrolling bar 603, and as long as it value remains positive and 
less than or equal to the number of records 731 defined within the STMT table 
730. Then control is given to step 805. 
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if the user action is a clicl< on the push-button "Imporf 605, then control is 
given to step 810; ' 
if the user action is a clicl< on the push-button "Done" 601 or on the 
closing-winclow push-button 615, then control is given to step 834; 
if the user action is a click on the push-button "Exporf 606, then control is 
given to step 811; 

if the user action is a click on the scrolling bar 603, either on the up direction or 
on the down direction, then control is given to step 814; 
if the user action is a click on the option buttons "Fonnaf 617, or "Profile" 609, 
or "Template" 616, then control is given to step 815; 

if the user action is a click on the check box "From current selection" 608, then 
control is given to step 81 6; 

if the user action is a click on a top check box like the check box 612, then 
control is given to step 817; 

if the user action is a click on the push-button "Instanciate" 604, then control is 
given to step 830; 

if the user action is a click on the push-button "Edif 611, then control is given 
to step 824 and; 

if the user action is a click on the push-button "Create New" 610, then control 
is given to step 818. 

At step 808, a test is performed on each of the records 731 of the STMT fable 
730 whose "Type" field 737 has the "selected" attribute 742 eiqlial to 'VEs",.to 
detemnine if this same "Type^' field 737 has.the "referenced" attribute 740 equal 
to **template" or "instance". 

• If it is the case, then control is given to step 835 (meaning that at least one 
record 731 of the STMT table 730 previously selected was referenced by a 
scalable template or by a scalable template instance); 

• othehA^ise control is given to step 809. 

At step 809, each respective record 701, 711. and 721 is removed from the EFT 
table 700. EPT table 710, and STT table 720 if the corresponding respective 
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are derived from the "Type^ field 737 (attributes "nature" 741 and "meta" 739) 
of the following records 731 of the STMT table 730. 
. The "Modified" infomnatlon appearing on the top of the list box 602 
con^esponds to the "Last Change Dat^' field 733 of the record 731 In the 
5 STMT table 730 whose "/ndeV field 738 is equal to the local variable 

STMJndex. Underneath "Modified" infonnation's within this list box 613 
con'espond to the "Lasf Change DateT field 733 of the following records 731 
of the STMT table 730. 

• The check box 612 is filted with a check marie if the "Type" field 737 of the 
10 record 731 in the STMT table 730 whose "/ncfeV' field 738 is equal to the local . 

variable STMJndex has the "selected" attribute 742 equal to "yes". 
Underneath check boxes on the left of the list box 613 are also derived from 
the "Type" field 737 ("selected" attribute 742) of the following records 731 of 
. the STMT table 730. 

13 • The pption button "Fomnat' 617 displays a black point if and only if the local 
variable STM^new is equal to "FORMAT. The option button "Profile" 609 
displays a black point if and only if the local variable STM_new is equal to 
"PROFILE". The option button Template" 616 displays a black point if and 
only if the local variable STM^new is equal to "TEMPLATE". 

20 • The check box "From cun-ent selection" 608 displays a check mark if and only ; 
if the local variable STM^range is equal to "yes". 

• At step 806, the method is waiting for any user action on the Scalable Template 
Manager Dialog Box 600. Such user action is typically resulting from a click with 
the pointing device 105, but take other similar forms such as, but not limited to a 

25 specific combination of key on the keyboard 104, or any other similar means not 
further specified here. 

• At step 807, a user action on the Scalable Template Manager Dialog Box 600 is 
detected. 

• If the user action is a click on the push-button "Delete" 607, then control is 
30 given to step 808; 
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• At step . 804, the three tables EFT 700, EPT 710, and STT 720 are parsed to 
derive the table STMT 730. For each respective record 701 . or 71 1 , or 721 found 
in one of these three tables; is created a new record 731 within the STMT table 
730. 

5 Referring now to. FIG 7A, 7B, 7C, and 7D, this construction is done by copying in 
sequence all. the fields defined in the record 701 {"Nam^ field 702, "Last Change 
DateT field 703, "Description Ptf field 704, 'Row r field 705, "Column #" field 
706 and "TypeT field 707) or in the record 711 ("A/ame" field 712. "Last Change 
. Dat^ field 713, "Description Ptf field 714, "flow #" field 715, "Column #" field 

.10 716 and "Typd' field 717), or in the record 721 ("A/ame'' field 722, "Last Change 
Datei' field 723, "Description Ri" field 724, "M/n Element #" field 725, "Max 
.. Element #" field 726 and "TypeT field 727) onto the con-esponding. fields of the 
record 731 ("A/ame^ field 732, "Last Change Dat^ field 733, "Description Ptr 
field 734, "Info Field f* field 735, "Info Field Z field 736 and "Tj^e'' field 737), 

15 then by initialising in; the "Typef field 737 the "selected" attribute 742 to "no" and 
the "nature" attribute 741 to the values "format", or "profile" or "template" if the 
record 731 has been retspectlvely copied from a record 701 , or 71 1 , 6r 721 , and 
then by initialising the last field "/nofex" 738 with , the value of a csouriter which 
increments for each new record and which starts with the value 1 (one). . 

20. • At step 805, the Scalable Template Manager Dialog Box 600 is displayed oh the 
display device 106. 

. . • The "Name" infomiation appearing on the top of the list box 613 corresponds 
to the "Name!' field 732 of the record 731 in the STMT table 730 whose 
"/ncyex" field 738 is equal to the local variable STMJndex. Underneath 
25 "Name" infomiation's within this list box eiS.con-espohd to the "Nam^ field 

732 of the following records 731 of the STMT table 730. 
• The 'Type' infomiation appearing on the top of the list box 614 Is derived 
from the "Typ^ field 737 (attributes "nature" 741 and "meta" 739) of the record 
731 in the STMT table 730 whose "//icfex" field 738 is equal to the local 
30 variable STMJndex. Undemeath "Type" information's within this list box 613 
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• the possibility to update the sorting criteria in tenns of prioritised column 
sequence. 

Once the spreadsheet user has specified the sorting application options, then 
this sorting application is perfomied on the reshaped range of cells, according 
5 to the specified options. Upon completion of this conventional sorting 

application, the Scalable Template Instance Sort Manager Dialog Box 2920 is 
closed to complete the processing of the Scalable Template Instance Sort 
Application Manager command. 

E.METHODS 

10 E1. Scalable Template Manager method 

The method for managing element formats, meta-elements fomiats, element 
profiles, meta-element profiles and scalable templates used in the preferred 
embodiment of the present invention is summarised in flowchart 800 of FIG 8. This 
method can be seen as the processing of the Scalable Template Manager 
15 command. . 

• At step 801 , the method is in its default state, waiting for an event to initiate the 
process. 

At step 802, the Scalable Template Manager command is detected, as a result 
of a user action. This action can be for instance: 

• a specific combination of key on the keyboard 1 04, or 

• the click of the pointing device 105 on a specific button, or 

• any other similar means not further specified here. 

At step 803, some local variables are initialised: 

• the local variable STM_select is set to the value 0 (zero), 

• the local variable STM_new is set to the value "none", 

• the local variable STM^range is set to the value "no", and 

• the local variable STMJndex is set to the value 1 (one). 
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• by 2925 label box when the option button 2930 displays a black point, or 

• by the 2926 label box when the option button 2929 displays a black point, 
or 

• by the 2927 label box when the option button 2928' displays a black point, 

. S then the sorting application is considered as impossible, so that the ''Sort' 

push-button 2923 gets disabled. 

Reversely, if the value "yes" is displayed instead of the value "no", then the 
sorting application is possible, so that the ''Sorf push-button 2923 gets 
enabled. When the "Sort" push-button 2923 is enabled and clicked with the 
10 pointing device 105 by the spreadsheet user, the. selected sorting mode is 

used to detemnine how to reshape the currently selected range of cells. 
If the selected sorting mode is the "range" mode (option button 2930 
displaying a black point), then the cun^ently selected range of cells is kept as 
is. 

.15 ; If the selected sorting mode is the "element" mode (option button 2929 
displaying a black point), then the currently selected range of cells is 
reshaped to corespond to the elements which on one side are part of the 
scalable template instance to which the cun-ently selected cell belongjs, and 
which on the other side occupy the rows of the currently selected range of 

20 cells. 

If the selected sorting mode is the "instance" mode (option button 2928 
displaying a black point), then the currently selected range of cells is 
. reshaped to corriespond to the whole body part of the scalable template 
instance to which the currently selected cell belongs. 

25 Once the reshape is done, a conventional sorting application is invoked for 

the reshaped range of cells, so that the spreadisheet user can first specify 
through conventional means (such as clicking with the. pointing device 105 on 
push-buttons, options buttons, check boxes, or any other equivalent dialog 
box components) the conventional options available in electronic spreadsheet 

30 environments for sorting ranges of cells. Such options are for instance 

• the possibility to exclude or include the first row of the selected range of 
cells, or 

• the possibility to perform an ascending or descending sorting operation, or 
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without further action. By clicking with the pointing device 105 on one of these 
two push-buttons 2921 and 2922, the Scalable Template Instance Sort 
Manager Dialog Box 2920 is closed and the sorting appiicatidn is aborted. 

Fourth the push-button "Sorf 2923, when clicked with the pointing device 105 
by the spreadsheet user, is the trigger launching the sorting application. This 
push-button "Sort 2923 Is enabled (meaning that the method recognises the 
click event with the pointing device 105 on this push-button "Sort' 2923) when 
the sorting application is possible. The fact that this sorting application is 
possible or not depends on different factors: 

• the position of the currently selected cell within an . existing scalable 
template instance, 

• the, overlap of the currently selected range of cells with existing scalable 
template instance(s), the sorting mode, and 

• the presence of any existing critical scalable template instance which 
would be cormpted due to the sorting application. 

The possibility to perform or not the sorting application according to the 
sorting mode specified by one of the three option buttons. 2930; 2929, and 
2928, is reflected by several label boxes, taking the values "yes" or "no", which 
are part of the Scalable Template Instance Sort Manager Dialog Box 2920. 
The two label boxes 2932 and 2933 reflect for the sorting mode "range" if the 
sorting application may lead to conrupt any existing critical scalable template 
instance (label box 2932), or may lead to corrupt any other existing scalable 
template instance (label box 2933). 

As soon as the value "yes" (respectively "no") is taken by the 2932 label box, 
the label box 2925 located in the "Possible^ column 2924 takes the value "no" 
(respectively "yes") reflecting that the sorting mode "range" is not possible. 
The label box 2926 takes the value 'Ves" as soon as the currently selected 
cell is located within an existing scalable template instance, so that the 
"element" sorting mode is possible. 

The label box 2927 takes the value *Ves" as soon as the currently selected 
cell is located within an existing scalable template instance, so that the 
"instance" sorting mode is possible. As soon as the value "no" is taken 
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template instance to which the currently selected cell belongs, and which on 

the other side occupy the rows of the currently selected range of cells. 

The third sorting mode is the "instance" mode where the range of cells to be 

sorted corresponds to the whole body part of the scalable template instance 

to which the currently selected cell belongs (in other words it con^esponds to 

all the elements defined within this scalable template instance). 

To detemiine which sorting mode to use, the Scalable Template Instance 

Sort Manager Dialog Box. 2920 is displayed on the display device 106, as 

illustrated by l=IG 29B. This Scalable Template Instance Sort Manager Dialog 

Box 2920 contains some pieces of Infbirmation which relate to the sorting 

application. 

First the name of the scalable template that the scalable template instance to 
which the currently selected cell belongs, abides by, is displayed in the label 
box 2931 (if such a scalable template instance does not exist, then the label 
box 2931 displays the reserved name "none"). 

Second the sorting mode is specified by the presence of a black point within 
one of the three option buttons "Sort as a range of cell^ 2930, "Sort as 
etement^ 2929, and ''Sort as an Instanc^ 2928, respectively, corresponding 
to the sorting modes "range", "element and "instance". If the spreadsheet user 
wishes to change the default sorting mode which is "range" in a preferred 
embodiment of the present invention, or a previously changed sorting, mode, 
then he/she uses the pointing device 105 to click on one of the three option 
buttons 

• ''Sort as a range of cell^ 2930, 

• "Sort as elements 2929, and 

• "Sort as an Instance 2926, 

which will display alone a black point specifying the new selected sorting 
mode. 

Third the push-button "Cancef- 2922 or the closing-window push-button 2921 
allow to close the Scalable Template Instance Sort Manager Dialog Box 2920 
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a. The spreadsheet user first selects a range of cells of his/her choice by 
using conventional means, such as but not limited to the pointing device 105 
or the keyboard 1 04. 

b. Scalable Template Instance Sort Application Manager 

Then the spreadsheet user jnvokes an original specific command called 
"Scalable Template Instance Sort Application Managef thanks to 
conventional means available in spreadsheet environment, such as but not 
limited to the pointing device 105 or the keyboard 104, in order to sort part or 
totality of a scalable template instance identified by the currently selected 
range of cells. 

When the Scalable Template Instance Sort Application l^anager 
command is invoked, a test is first perfomned to determine if the currently 
selected range of cells overlaps or not (totally or partially) one or several 
existing scalable template instances. 

If it is not the case, then the conventional sorting application available in 
electronic spreadsheet environments is invoked to sort the currently selected 
range of cells. 

If it is the case, then a second test is performed to detemiine if the currently 
selected cell belongs or not to an existing scalable template instance. 
If it is not the case, then a conventional sorting application will be possible, at 
the cost of corrupting the existing scalable template instances which overiap 
with the currently selected range of cells. 

If it is the case, then three different modes of sorting become possible. 
The first sorting mode is the "range" nriode which corresppnds to the 
conventional sorting application where the currently selected range of cells is 
sorted according to user-specified parameters. With this first mode, any 
existing scalable template instance overlapping with the sorted range of cells 
will be corrupted. 

The second sorting mode is the "element" mode where the range of cells to be 
sorted corresponds to the elements which on one side are part of the scalable 
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three push-buttons 2722, 2727 and 2728 available within the Scalable 
Template Import Instance Manager Dialog Box 2720. 
If the user-specified existing file is a correct spreadsheet instance 
export-Import file, then the Scalable Template Instance Import Manager 
Dialog Box 2720 is updated as the text box 2723 displays the name of the 
spreadsheet instance export-import file. Then the Instance Import operation is 
launched by copying-pasting by value,, from the spreadsheet instance 
export-import file towards the current spreadsheet file, . every "IN" cell 
belonging to the scalable template instance containing the currently selected 
cell. The progress of the Instance Import operation is reflected by the 
progress bar 2726 which graphically translates the portion of completed 
processing of the Instance Import operation. When the Instance Import 
operation is over, the Scalable Template Instance Import Manager Dialog Box 
2720 is closed on the display device 106, and the spreadsheet instance 
export-import file (either new or updated) is ready to be imported to another 
spreadsheet file. 

In the specific case where the source spreadsheet file and the destination 
spreadsheet file are in fact the same spreadsheet file,, the previous method 
and commands can be used identically. In this case, the proposed 
import-export method can be seen as an intelligent, scalable template minded 
way to perfonn a copy-and-paste operation frorh a source scalable template 
instance onto a destination scalable template instance belonging to the same 
spreadsheet file. 

8. Eighth Operation : Reorganisation of Scalable Template Instance 

The eighth operation occurs when the spreadsheet user decides, based on his or 
her own criteria not detailed here, to use a sorting application available in 
electronic spreadsheet environments to reorganise a scalable template instance. 
In a preferred embodiment of the present invention, this operation comprises the 
following steps: 
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• name or rename the range of cells corresponding to the scalable template 
instance to which the currently selected cell belongs (by clicking with the 
pointing device 105 on the "A/ame or Rename the Instance,'' push-button 
2727). 

If the ''Cancer push-button 2722 is clicked, then the Scalable Template 
Instance Import Dialog Box 2720 is closed and the Instance Import operation 
completes without any further action. 

If the "A/a/ne or Rename the Instance push-button 2727 is clicked, then a 
conventional range of cells naming dialog box is displayed on the display 
device 106 to let the spreadsheet user assign a name to the range of cells 
coresponding to the scalable template instance containing the currently 
selected cell. Any similar conventional means could also be used instead of 
the range of cells naming dialog box without departing from the spirit of the 
present invention. 

If the "Select an Import Filel' push-button 2728 is enabled and clicked, then a 
conventional file selection dialog box is displayed on the display device 106 to 
let the spreadsheet user navigate within the existing file directory structure, 
and then select an existing file within a file directory. Any similar conventional 
means could also be used instead of the file selection dialog box without 
departing from the spirit of the present invention. 

Once the existing file has been specified by the spreadsheet user, a test is 
perfdmned to check if this file is a valid spreadsheet instance export-import 
file, and follows as such a pre-defined logical file structure. 
If it is not the case, then the spreadsheet user is warned dbout this situation. 
To this effect a warning message is issued on the display device 106 through 
conventional means such as pop-up windows, status bar messages, or any 
other similar conventional means which can be used instead without 
departing from the spirit of the invention. This warning message infonns the 
spreadsheet user about this situation, and the spreadsheet user is then 
invited through conventional prompting means such as an "0/C push-button, 
to acknowledge the waming. The warning message is then closed, so that the 
spreadsheet user can click again with the pointing device 105 on one of the 
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cell must be located within an existing scalable template instance to enable 
the Instance Import operation. 

If it is the case, then the Scalable Template Instance Import Dialog Box 2720 
is displayed on the display device 106, as illustrated by the FIG 27B. When 
first displayed, the Scalable Template Instance Import Dialog Box 2720 
contains three informative dialog boxes and three push-buttons, leaving to the 
. spreadsheet user the choice between different.acfions. The text boxes are . 

• the "Import FM text box 2723 which displays the name of the 
spreadsheet instance Import file, once specified (if .not specified, the name 
of the spreadsheet instance Import file defaults to an empty character 
string), 

• the text box "Instance NameT 2724 which displays tlie name of the range 
of cells corresponding to the scalable template instance to which the 
currently selected cell belongs, and 

• the ""Template Name" 2725 text box which displays the name of the 
scalable template that the scalable tenriplate instance to which the 
currently selected cell belongs, abides by. 

If the ""Instance Nam^ text box 2724 does not display a valid range of cells 
name (meaning that the range of cells corresponding to the scalable teoiplate 
instance containing the currently selected cell has not yet been named), then 
the push-button ""Select an Import Filer 2728 is disabled, so that any click with 
the pointing device 105 on it will not be recognised as a valid event. 
Reversely if the ""Instance Nam^' text box 272 displays a valid range of cells 
name, then the push-button ""Select an Import FM 2728 is enabled, so that 
any click with the pointing device 105 on it will be recognised as a valid event. 

The spreadsheet user can 

• either cancel the Instance Import operation (by clicking with the pointing 
device 105 on the ""Cancer push-button 2722), or 

• start an Import operation from an already existing spreadsheet instance 
export-import file to be selected (by clicking with the pointing device 105 
on the ^Select an Import F/Ze" push-button 2728 when enabled), or 



138 



wo 03/014987 



PCT/EP02/09483 



The second choice is to click with the pointing device 105 on the "Ye^ 
push-button 2710 to proceed with the Instance Export operation, that is to 
replace the current exported instance recorded in the spreadsheet Instance 
export-import file by the one which will be derived from the cunrent 
spreadsheet file. 

Once the spreadsheet user has clicked with the pointing device 105 on one of 
the two push-buttons 2709, or 2710, the franrie 2711 disappears from the 
Scalable Template Instance Export Manager Dialog Box 2700 with all the 
graphical objects it contains (labels, text boxes and push-buttons). 

If not stopped by the spreadsheet user by a click| on the "NcT push-button 
2709 as aforementioned, the progress of the Instance Export operation is 
reflected by the progress bar 2706 which graphically translates the portion of 
completed processing of the Instance Export operation. When, the Instance 
Export operation is over, the Scalable Template. Instance Export Manager 
Dialog Box 2700 is closed on the display device 106, and the spreadsheet 
instance export-import file (either new or updated) is ready to be imported to 
another spreadsheet file. 

• c. Scalable Template Instance Import Manager 

Then the spreadsheet user moves to another electronic spreadsheet file and 
then invokes an original specific command called "Scalable Template 
Instance Import Manage f thanks to conventional means available in 
spreadsheet environment, such as but not limited to the pointing device 105 
or the keyboard 104, in order to retrieve from a spreadsheet instance 
export-import file a scalable template instance. 

When the Scalable Template Instance Import Manager command is 
invoked, a test is first perfomned to determine if the currently selected cell 
belongs or not to an existing scalable template instance. 
If it is not the case, then a conventional pop-up window is displayed on the 
display device 106 to infomn the spreadsheet user that the currently selected 



137 



wO 03/0i4957 



invited through conventional prompting means such as an "OK" push-button, 
to acknowledge the waming. The waming message is then closed, so that the 
spreadsheet user can click again with the pointing device 105 on one of the 
four push-buttons 2702, 2712, 2713 and 2714 available within the Scalable 
Template Export Instance Manager Dialog Box 2700. 
If the user-specifed existing file is a correct spreadsheet instance 
export-import file, or if the user choice was to create a new spreadsheet 
Instance, export-import file, then the Scalable Terriplate Instance Export 
Manager Dialog Box 2700 is updated as the text box 2703 displays the name 
of the spreadsheet instance export-import file. 

Then the Instance Export operation is launched by copying-pasting by value, 
from the spreadsheet file towards the spreadsheet instance export-import file, 
every "IN" cell belonging to the scalable template instance containing the 
currently selected cell. If the spreadsheet/instance export-import file was 
already containing the result of a previous instance export operation from a 
scalable template instance sharing the same name, then a conflict is 
possible. 

If this situation arises, then the Scalable Tempjate Instance Export Manager 
Dialog Box 2700 is completed with a set of infonriation, all contained within 
the frame 2711.. 

• First the date associated to the previous Instance Export operation found 
in the specified spreadsheet instance expbrt-iniport file is displayed in the 
text box 2707. 

• Second the name of the file from which the previous instance has been 
exported in the specified spreadsheet instance export-import file is 
displayed in the text box 2708. 

By receiving all this information, the spreadsheet user can decide how to 
handle this conflict. 

The first choice is to click with the pointing device 105 on the "A/o" 
push-button 2709 to prevent the Instance Export operation, so that the fomier 
exported instance recorded within the specified spreadsheet instance 
export-import file is kept unchanged. 
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pointing device 105 on the ""Name or Rename the Instance" push-button 
2712). 

If the "Cancer push-button 2702 is clicked, then the Scalable Template 
Instance Export Dialog Box 2700 is closed and the Instance Export operation 
completes without any further action. 

If the "Name or Rename the Instance push-button 2712 is clicked, then a 
conventional range of cells naming dialog box is displayed on the display 
device 106 to let the spreadsheet user assign a name to the range of cells 
corresponding to the scalable template instance containing the currently 
selected cell Any similar conventional means could also be used instead of 
the range of cells naming dialog box without departing from the spirit of the 
present invention. 

If the "Export in a NEW fil^ push-button 2714 is enabled and clicked, then a . 
conventional file creation dialog box is displayed on the display device 106 to 
let the spreadsheet user navigate within the existing file directory structure, 
name and create a new file within a selected file directory. Any similar 
conventional means could also be used instead of the file creation dialog box 
without departing from the spirit of the present invention. 
If the "Export in an EXISTING filer push-button 2713 is enabled and clicked, 
then a conventional file selection dialog box is displayed on the display device 
106 to let the spreadsheet user navigate within the existing file directory 
stmcture, and then select an existing file within a file directory. Any similar 
conventional means could also be used instead of the file selection dialog box 
without departing from the spirit of the present invention. 
Once the existing file has been specified by the spreadsheet user, a test is 
performed to check if this file is a valid spreadsheet instance export-import 
file, and follows as such a pre-defined logical file structure. 
If it is not the case, then the spreadsheet user is wamed about this situation. 
To this effect a warning message is issued on the display device 106 through 
conventional means such as pop-up windows, status bar messages, or any 
other similar conventional means which can be used instead without 
departing from the spirit of the invention. This warning message infomis the 
spreadsheet user about this situation, and the spreadsheet user is then 
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• the text box ""Instance Namef 2704 which displays the name of the range 
of cells con-esponding to the scalable template instance to which the 
cun^ently selected cell belongs, and 

• the "Template NameP 2705 text box which displays the name of the 
S scalable template that the scalable template instance to which the 

cun-ently selected cell belongs, abides by. 
If the "Instance Nam^ text box 2704 does not display a valid range of cells 
name (meaning that the range of cells con-espondihg .to the scalable template 
instance containing the currently selected cell has not yet been named), then 
10 the two push-buttons: 

• . "Export /n a A/EkV/y/e^ 2714, and 

• "Export in an EXISTING file" 2713, 

are disabled, so that any click with the pointing device 105 oh them will not be 
recognised as a valid event. . 
15 Reversely if the "Instance Nam^ text box 2704 displays; a valid . riange of cells 

name, then the two push-buttons 

• "Export in a NEW fil^27U, and 

• "Export in an EXISTING fiW 27'i3, 

are enabled, so that any click with the pointing device 105 on them will be 
20 . recbgnised as a valid event. 

The spreadsheet user can 

• either cancel the Instance Export operation (by clicking with the pointing 
device 105 on the "CanceP push-button 2702), or 

25 • start an Export operation in a new spreadsheet instance export-import file 

to be created (by clicking with the pointing device 105 on the "Export in a 
NEWfild" push-button 2714 when enabled), or 

• start an Export operation in an already existing spreadsheet instance 
export-import file to be selected (by clicking with the pointing device 105 

30 on the "Export in an EXISTING filer push-button 271 3 when enabled), or 

• name or rename the range of cells corresponding to the scalable template 
instance to which the currently selected cell belongs (by clicking with the 
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a destination spreadsheet file. In a prefen^ed embodiment of the present 
invention, this operation comprises the following steps: 

• a. The. spreadsheet user first selects a range of cells of his/her choice by 
using conventional means, such as but not limited to the pointing device 105 
5 or the keyboard 1 04. This range of cells comprises the cunrently selected cell. 

. . • b. Scalable Template Instance Export Manager 

Then the spreadsheet user invokes an original specific command called 
""Scalable Template Instance Export Managef thanks to conventional 
10 means available in spreadsheet environment, such as but not limited to the 

pointing device 105 or the keyboard 104, in order to store in an Export/Import 
file the scalable template instance identified through the currently selected 
range of cells. 

15 When the Scalable Template Instance Export Manager command is 

invoked, a test is first performed to detennine if the cun-ently selected cell 
belongs or not to an existing scalable template instance. 
If it is not the case, then a conventional pop-up window is displayed on the 
display device 106 to infomn the spreadsheet user that the cunrently selected 

20 cell must be located within an existing scalable template instance to enable 

the Instance Export operjation. 

If it is the case, then the Scalable Template Instance Export Dialog Box 2700 
is displayed on the display device 106, as illustrated by the FIG 27A. When 
first displayed, the Scalable Template Instance Export Dialog Box 2700 
25 contains three infomnative dialog boxes and four push-buttons, leaving to the 

spreadsheet user the choice between different actions. The text boxes are 
• the "Export Filer text box 2703 which displays the name of the 
spreadsheet instance export file, once specified (if not specified, the name 
of the spreadsheet instance export file defaults to an empty character 
30 string), 
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• Second the date associated to the object version found In the spreadsheet 
file is displayed in the text box 2626. 

• Third the date associated to the object version recorded in the 
export-import file is displayed in the text box 2627. 

By receiving all this information, the spreadsheet user can decide how to 
handle this conflict. 

The first choice is to click with the pointing devjce 105 on the "A/d" 
push-button 2628 to prevent the Import operation for this specific object, so 
that the former version recorded within the spreadsheet file is kept 
unchanged. 

The second choice is to click with the pointing device 105 on the "Ves^ 
push-button 2630 to proceed with the Import operation for this specific object, 
that is to replace the current object version definition recorded in the 
spreadsheet file by the one defined as part of the export-import file. 
The third choice is to click with the pointing device 105 on the "Ves to Air 
push-button 2629 to proceed with the Import operation for this specific object, 
but also for any other object which would also fall In the same type of conflict 
case. 

Once the spreadsheet user has clicked with the pointing device 105 on one of 
the three push-buttons 2628, 2629, or 2630, the frame 2631 disappears from 
the Scalable Template Import Manager Dialog Box 2620 with all the graphical 
objects It contains (labels, text boxes and push-buttons). When all the objects 
part of the set of selected objects (element formats or meta-element formats 
or element profiles or meta-element profiles or scalable templates) have been 
processed by the Import operation, the Scalable Template Import Manager 
Dialog Box 2620 is closed on the display device 106, and the current 
spreadsheet file has been updated by the definitions imported from the 
export-import file. 

7. Seventh Operation : Import / Export of Scalable Template Instance 

The seventh operation occurs when the spreadsheet user decides, based on his 
or her own criteria not detailed here, to share, through an import / export 
mechanism, a scalable template instance between a source spreadsheet file and 
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could also be used Instead of the file selection dialog box without departing 
from the spirit of the present invention. 

Once the existing file has been specified by the spreadsheet user, a test is 
perfomied to check If this file is a valid export-import file, and follows as such 
a pre-defined logical file structure. 

If it is not the case, then the spreadsheet user is warned about this situation. 
To this effect a warning message is issued on the display device 106 through 
conventional means such as pop-up windows, status bar messages, or any 
other similar conventional means which can be used instead without 
departing from the spirit of the invention. This warning message infomis the 
spreadsheet user about this file case, and the spreadsheet user is then 
invited through conventional prompting means such as an "0/C push-button, 
to acknowledge the waming. The warning message is then closed, so that the 
spreadsheet user can click again with the pointing device 105 on one of the 
two push-buttons 2622, and 2632 available within the Scalable Template 
Import Manager Dialog Box 2620. 

If the user-specifed file is a correct export-import file, then the Scalable 
Template Import Manager Dialog Box 2620 is completed with the text box 
2623 displaying the name of the export-import file. Then the Import operation 
is launched by moving (from the export-import file towards the spreadsheet 
file) one by one every element fomnat or meta-element forniat or element 
profile or meta-element profile or scalable template recorded in the 
export-import file. The progress of the Import operation is reflected by the 
progress bar 2624 which graphically translates the portion of processing 
already completed of the whole Import operation. 

During this Import operation, a potential conflict may be identified between a 
version of an object (either an element format or a meta-element fomiat or an 
element profile or a meta-element profile or a scalable template) already 
defined within the spreadsheet file and a version recorded within this 
export-import file. If this situation arises, then the Scalable Template Import 
Manager Dialog Box 2620 is completed with a set of information, all 
contained within the frame 2631. 

• First the name of the conflicting object is displayed in the text box 2625. 
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file. 



c. Scalable Template Import Manager 

Then the spreadsheet user moves to another electronic spreadsheet file and 
then invokes an original specific command called "Scalable Template Import 
Managef thanks to conventional means available in spreadsheet 
environment, such as but not limited to the pointing device 105 or the 
keyboard 104, in order to retrieve from an export-import file a set of one or 
several 

element fonnats and/or 
meta-element fomnats and/or 
element profiles and/or 
meta-element profiles and/or 
scalable templates. 



This can be illustrated with the user interface described with the FIG' 26B, 
showing the Scalable Template Irhport Dialog Box 2620, as displayed on the 
display device 106. When first displayed, the Scalable Ternplate Import 
Dialog Box 2620 contains two push-buttons, leaving to the spreadsheet user 
the choice 

• to either cancel the Import operation (by clicking with the pointing device 
105 on the ''Cancer push-button 2622). or 

• to start an Import, operation from an already existing export-irriport file to 
be selected (by clicking with the pointing device 105 on the ^Select an 
/mport F//e^ push-button 2632). 

If the ''Cancer push-button 2622 is clicked, then the Scalable Template 
Import Dialog Box 2620 is closed and the Import operation completes without 
any further action. 

If the "Select an import Fil^ push-button 2632 is clicked, then a conventional 
file selection dialog box is displayed on the display device 106 to let the 
spreadsheet user navigate within the existing file directory structure, and then 
select an existing file within a file directory. Any similar conventional means 
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element profile or a meta-element profile or a scalable template) previously 
exported within this export-import file and a new version of the same object 
candidate to be exported. If this situation arises, then the Scalable Template 
Export Manager Dialog Box 2600 is completed with a set of information, all 
contained within the frame 2611. 

• First the name of the conflicting object is displayed in the text box 2605. 

• Second the date associated to the object version found in the specified 
export-import file is displayed in the text box 2606. 

• Third the date associated to the object candidate for export is displayed in 
the text box 2607. 

By receiving all this infomaation, the spreadsheet user can decide how to 
handle this conflict. 

The first choice is to click with the pointing device 105 on the "No" 
push-button 2608 to prevent the Export operation for this specific object, so 
that the former version recorded within the specified export-import file is kept 
unchanged. 

The second choice is to click with the pointing device 105 on the "Yef 
push-button 2610 to proceed with the Export operation for this specific object,, 
that is to replace the current object version definition recorded in the 
export-import file by the one defined as part of the current spreadsheet ifile. 
The third choice is to click with the pointing device 105 on the "Yes to, Air 
push-button 2609 to proceed with the Export operation for this specific object, 
but also for any other object which would also fall in the same type of conflict 
case. 

Once the spreadsheet user has clicked with the pointing device 105 on on^ of 
the three push-buttons 2608, 2609, or 2610, the frame 2611 disappears from 
the Scalable Template Export Manager Dialog Box 2600 with all the graphical 
objects it contains (labels, text boxes and push-buttons). When ail the objects 
part of the set of selected objects (element fomnats or meta-element fomnats 
or element profiles or meta-element profiles or scalable templates) have been 
processed by the Export operation, the Scalable Template Export Manager 
Dialog Box 2600 is closed on the display device 106, and the export-import 
file (either new or updated) is ready to be imported to another spreadsheet 
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If the "Export //? an EXISTING fild* push-button 2613 is clicked, then a 
conventional file selection dialog box is displayed on the display device 106 to 
let the spreadsheet user navigate within the existing file directory structure, 
and then select an existing file within a file directory. Any similar conventional 
means could also be used instead of the file selection dialog box without 
departing from the spirit of the present invention. 

Once the existing file has been specified by the spreadsheet user,, a test is 
perfonmed to check if this file is a valid export-import file, and follows as such 
a pre-defined logical file structure. 

If it is not the case, then the spreadsheet user is wamed about this situation. 
To this effect a waming message is issued on the display device 106 through 
conventional means such as pop-up windows, status bar messages, or any 
other similar conventional means which can be used instead without 
departing from the spirit of the invention. This warning message infonns.the 
spreadsheet user about this file case, and the spreadsheet user is then 
invited through conventional prompting means, such as an "OK" push-button, 
to acknowledge the warning. The warning message is then closed, so that the 
spreadsheet user can click again with the pointing device 105 on one of the 
three push-buttons 2602. 2612 and 2613 available within the Scalable 
Template Export Manager Dialog Box 2600. 

If the user-specifed existing file is a correct export-import file, or if the user 
choice, was to create a new export-import file, then the Scalable Template 
Export Manager Dialog Box 2600 is completed with the text box 2603 
displaying the name of the export-import file. 

Then the Export operation is launched by moving (from the spreadsheet file 
towards the export-import file) one by one every member of the set of 
selected element fomnats or meta-element fomriats or element profiles or 
meta-element profiles or scalable templates. The progress of the Export 
operation is reflected by the progress bar 2604 which graphically translates 
the portion of processing already completed of the whole Export operation. 
During this Export operation, in the case where the export-import file was an 
already existing one, a potential conflict may be identified between a version 
of an object (either an element format or a meta-element fomiat or an 
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formats, or meta-element formats, or element profiles, or meta-element 
profiles, or scalable templates. 

• b. Scalable Template Export Manager 

5 Then the spreadsheet user invokes an original specific command called 

"Scalable Template Export Managef thanks to conventional means 
available in spreadsheet environment, such as but not limited to the pointing 
device 105 or the keyboard 104, in order to store in an Export/Import file the 
set of selected element fonm.ats or meta-element formats or element profiles 

10 or meta-element profiles or scalable templates. 

This can be illustrated with the user interface described with the FIG 26A, 
showing the Scalable Template Export Dialog Box 2600, as displayed on the 
display device 106. When first displayed, the Scalable Template Export 
IS Dialog Box 2600 contains three push-buttons, leaving to the spreadsheet 

user the choice 

• to either cancel the Export operation (by clicking with the pointing device • 
105 on the ''Cancer push-button 2602), or 

• to start an Export operation in a new export-import file to be created (by 
20 clicking with the pointing device 105 on the Export in a NEW fild' 

push-button 2612), or 

• to start an Export operation in an already existing export-import file to be 
selected (by clicking with the pointing device 105 on the Export in an 
EXISTING filer push-button 2613). 

25 if the "Cancer push-button 2602 is clicked, then the Scalable Template 

Export Dialog Box 2600 is closed and the Export operation completes without 
any further action. 

If the ''Export in a NEW fild' push-button 2612 is clicked, then a conventional 
file creation dialog box is displayed on the display device 106 to let the 
30 spreadsheet user navigate within the existing file directory structure, name 

and create a new file within a selected file directory. Any similar conventional 
means could also be used instead of the file creation dialog box without 
departing from the spirit of the present invention. 
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of cells. When the paste mode is equal to ''instance", the newly created 
range of cells is recorded as a valid scalable template instance in the 
spreadsheet environment and replaces the scalable template instance 
which the cun^ently selected cells was belonging to. 
S Finally the Scalable Template Instance Paste Manager Dialog Box 2340 is 

closed to complete the processing of the Scalable Template Instance Paste 
command. . . 

• 6. Sixth Operation : Import / Export of Element Format, Element Profile, 
Scalable Template 

10 The sixth operation occurs when the spreadsheet user decides, based on his or 
her own criteria not detailed here, to share, through an import / export 
mechanism, a set of one or several 

• element formats, and/or 

• meta-element formats, and/or 
15 . • element profiles, and/or 

. • meta-element profiles, and/or 

• scalable templates, 

between a source spreadsheet file and a destination spreadsheet file. In a 
preferred embodiment of the present invention, this operation comprises the 
20 following steps: 

• a. The spreadsheet user invokes first an original specific command called 
"Scalable Template Manage!^ thanks to conventional means available in 
spreadsheet environment, such as but not limited to the pointing device 105 
or the keyboard 104, in order to visualise any existing : 

25 • element fomiat,. or 

• meta-element fonmat, or 

• element profile, or 

• meta-element profile, or 

• scalable template. 

30 This initial step corresponds to the first step of the first operation of this 

scenario, where the spreadsheet user can select one or multiple element 
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As soon as the value 'Ves" is taken by the 2352 label box, the label box 2345 
located in the "PossibleT column 2344 takes the value "no" reflecting that the 
cut mode "range" is not possible. 

The label box 2346 takes the value "yes" as soon as the "ELEMENf" paste mode 
5 is possible (fifth case in the aforementioned situations). 

The label box 2347 takes the value "yes" as soon as the "instance" paste 
mode is possible (seventh case in the aforementioned situations). As soon as 
the value "no" is taken 

• by the 2345 label box when the option button 2350 displays a black point, 
10 . or 

• by the 2346 label box when the option button 2349 displays a black point, 
or 

• by the 2347 label box when the option button 2348 displays a black point, 
then the paste operation is considered as impossible, so that the "Pasfe^' 

15 push-button 2343 get disabled. 

Reversely, if the value "yes" is displayed instead of the value "no", then the 
paste operation is possible, so that the "Pasfe" push-button 2343 get enabled. 
When the "Pastel' push-button 2343 is clicked, with the pointing device 105 by 
the spreadsheet user; the selected paste mode is used to detemilne how to 

20 reshape the range of cells dest_range. 

• If the selected paste mode is the "range" mode (option button 2350 
displaying a black point), then the range of cells dest^range is kept as is. . 

• If the selected paste mode is the "element" mode (option button 2349 
displaying a black point), then the range of cells dest^range |s reshaped to 

25 correspond to the elements and meta-elements which on one side are part 

of the scalable template instance to which the currently selected cell 
belongs, and which on the other side occupy the rows of the current position 
of the range of cells dest_range. 

• If the selected paste mode is the "instance" mode (option button 2348 
30 displaying a black point), then the range of cells dest_range is reshaped to 

correspond to the whole scalable template instance to which the currently 
selected cell belongs. Once the reshape is done, a conventional paste 
operation is perfomied from the memory clipboard onto the reshaped range 
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buttons "Pasfe as a range of cell^ 2350, "Pasfe as elements 2349, and 
"Paste as an Instance 2348 which will display alone a black point specifying 
the new selected paste mode. 

Fourth the push-button "Cancel 2342 or the closing-window push-button 
2341 allow to close the Scalable Template Instance Paste Manager Dialog 
Box 2340 without further action. By clicking with the pointing device 105 on 
one of these two push-buttons 2341 and 2342, the. Scalable Template 
Instance Paste Manager Dialog Box 2340 is closed and the paste operation is 
aborted. 

Fifth the push-button Paste" 2343, when clicked with the pointing device 105 
by the spreadsheet user, is the trigger launching the operation of paste. This 
push-button "Pasfe^* 2343 is enabled (meaning that the method recognises 
the click event with the pointing device 105 on this push-button "Pasfe^' 2343) 
when the paste operation is possible. The fact that this paste pperation is . 
possible or not depends on different factors: 

• the . position pf the currently selected cell within an existing scalable 
template instance, 

• the overlap pf the range pf cells dest_range with existing scalable, 
template instance(s), the mode of paste, 

• the last mode of copy or cut, and 

• the presence of any existing critical scalable template instance which 
would be corrupted due to the paste operation. 

The possibility to perform or not the paste operation according to the paste 
mode specified by one of the three option buttons 2350, 2349, and 2348, is 
reflected by several label boxes, taking the values "yes" or "no", which are part 
of the Scalable Template Instance Paste Manager Dialog Box 2340. 
The two label boxes 2352 and 2353 reflect for the paste mode "range" if the 
paste operation may lead to cormpt any existing critical scalable template 
instance (label box 2352), or may lead to corrupt any other existing scalable 
template instance (label box 2353). 
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• if the size of the scalable template instance copied or cut onto the 
clipboard is not the same as the size of the scalable template instance to 
which the currently selected cell belongs, 
then it is not possible to safely paste the whole scalable template instance 
from the clipboard onto the one to which the cunrently selected cell belongs. 
Therefore only the "range" paste mode is possible, at the cost of corrupting 
the overlapped scalable template instances. The spreadsheet user must thus 
be prompted to either continue or cancel the paste operation. 

To detemnine If the paste operation must be perfomned and which paste 
mode to use, the Scalable Template Instance Paste Manager Dialog Box 
2340 is displayed on the display device 106, as illustrated by FIG 23C. This 
Scalable Template Instance Paste Manager Dialog Box 2340 contains some 
pieces of Infomnatlon which relate to the paste operation. 

First the name of the scalable template that the scalable template instance to 
which the currently selected cell belongs, abides by, is displayed in the label 
box 2351 (if such a scalable template instance dpes not exist, then the label 
box 2351 displays the reserved name "none"). 

Second the name of the scalable template that the scalable template instance 
which has been previously copied or cut onto the clipboard, abides by, is 
displayed in the label box 2354 (if such a scalable template instance was not 
previously copied or cut onto the clipboard, then the label box 2354 displays 
the reserved name "none"). 

Third the paste mode is specified by the presence of a black point within one 
of the three option buttons "Pasfe as a range of cell^ 2350, ""Paste as 
elements 2349, and "Paste as an Instance 2348, respectively corresponding 
to the paste modes "range", "element and "instance". If the spreadsheet user 
wishes to change the default paste mode which is "range" In a pretended 
embodiment of the present invention, or a previously changed paste mode, 
then he/she uses the pointing device 105 to click on one of the three option 
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meta-elements of the scalable template Instance to which the currently 
selected cell belongs, and which are located on the same rows as the 
range of cells dest^range, 
then it Is not possible to safely paste (meta-)element by (meta-)element the 
clipboard onto the elements or meta-elements of the scalable template 
instance to which the currently selected cell belongs, and which are located 
on the same rows as the range of cells desl^range: Therefore only the 
"range" paste mode is possiblei at the cost of corrupting the overlapped 
scalable template instances. The spreadsheet user must thus be prompted to 
either continue or cancel the paste operation.. 

* ■ 

Seventh 

• if the previous copy or cut operation was done with the mode "instance" 
and 

• if the currently selected cell belongs to a scalable template instance and 

• if the size of the scalable template instance copied or cut onto the 
clipboard is the same as the size of the scalable template instance to 
which the currently selected cell belongs, 

then it is possible to safely paste the whole scalable template instance from 
the clipboard onto the one to which the currently selected cell belongs. This 
paste mode is refeaed to as the "instance" mode and the spreadsheet user 
must be prompted to select 

• this "instance" mode, or 

• the "range" mode, or 

• simply to cancel the paste operation. 

Eighth 

• If the previous copy or cut operation was done with the mode "instance" 
. and 

• if the cun-ently selected cell belongs to a scalable template instance and 
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• if the currently selected cell does not belong to a scalable template 
Instance and 

• If the range of cells desLrange overlaps at least one "OUT cell In the 
scalable template instances, 

then the overlapped scalable templates instances will be cormpted by the 
paste operation. The spreadsheet user must thus be prompted to either 
continue or cancel the paste operation. 

Fifth 

• if the previous copy or cut operation was done with the mode "element" 
and 

• if the currently selected cell belongs to a scalable template Instance and 

• if the structure of the elements or meta-elements copied or cut onto the 
clipboard Is the same as the stnjcture of the elements or meta-elements 
of the scalable template instance to which the currently selected cell 
belongs, and which are located on the same rows as the range of cells 
dest^range, 

then it is possible to safely paste {meta-)eiement by (meta-)elem,ent the 
clipboard onto the elements or meta-elements of the scalable template 
instance to which the currently selected cell belongs^ and which are located 
on the same rows as the range of cells desLrange, This paste mode is 
referred to as the "element" mode and the spreadsheet user must be 
prompted to select : 

• this "element mode, or 

• the "range" mode, or 

• simply to cancel the paste operation. 

Sixth 

• if the previous copy or cut operation was done with the mode "element" 
and 

• if the currently selected cell belongs to a scalable template instance and 

• if the structure of tfie elements or meta-elements copied or cut onto the 
clipboard is not the same as the structure of the elements or 
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• If the range of cells dest^range does overlap one or several existing 
scalable template instances, then several different situations are 
considered. 

First 

• if the previous copy or cut operation was done with the mode "range" and 

• if the range of cells dest^range only overlaps "IN" cells in the scalable 
template instances, 

then a conventional paste operation is perfomied from the clipboard onto the 
range of cells dest^range. 

Second 

• if the previous copy or cut operation was done with the mode "range" and 

• if the range of cells dest_range overlaps at least one "OUT" cell in the 
scalable template instances, 

then the overlapped scalable templates instances will be corrupted by the 
paste operation. The spreadsheet user must thus be prompted to either, 
continue or cancel the paste operation... 

Third 

• if the previous copy or cut operation was not dbne with the mode "range" 
and 

• if the currently selected cell does not belong, to a scalable template 
instance and 

• If. the range of cells dest_range only overlaps "IN" cells in the scalable 
template instances, 

then a conventional paste operation is performed from the clipboard onto the 
range of cells cfesLrangfe. 

Fourth 

• if the previous copy or cut operation was not done with the mode "range" 
and 
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Step consists in determining according to conventional means the range of 
cells which will receive the infomiation previously copied or cut onto the 
clipboard. This range of cells will be refen^ed to as the desLrange, 

• If the previously copied or cut range of cells is made of a single column 
and of multiple rows, then dest^range corresponds to a range of cells 
occupying the same columns as the currently selected range of cells, and 
occupying as many rows as the range of cells previously copied or cut. 

• If the previously copied or cut range of cells is made of a single row and of 
multiple columns, then desi_range corresponds to a range of cells 
occupying the same rows as the currently selected range of cells, and. 
occupying as many columns as the range of cells previously copied or cut. 

• If the previously copied or cut range of cqIIs is made of a single cell, then 
desLrange corresponds to the currently selected range of cells, 

• In all the other cases, dest_range occupies as many rows and columns as 
the previously copied, or cut range of cells, with the top left cell located on 
the position of the currently selected cell. 

Then an initial test is performed to detemiine if the range of cells dest__range 
overlaps or not (totally or partially) one or several existing scalable template 
instances. 

• If it is not the case, then a conventional Paste operation is perfomied from 
the clipboard onto the range of cells dest_range. This conventional paste 
mode of operation is referred to as the "range" paste mode. Then a 
second test is perfomied to determine if the previous copy or cut operation 
was done with the mode "instance". 

• If it is the case, then it means that a whole instance was present in the 
clipboard, so that the conventional Paste operation has created a new 
instance, and so that this new instance must be recorded within the 
spreadsheet environment. 

• If it is not the case, then the conventional Paste operation completes 
without further action. 
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If the selected cut mode Is the "element mode (option button 2329 displaying 
a black point), then the currently selected range of cells is reshaped to 
con^espond to the elements and meta-elements which on one side are part of 
the scalable template instance to which the cun'ently selected cell belongs, 
and which on the other side occupy the rows of the cun^ently selected range 
of cells. 

If the selected cut mode is the "instance" mode (option button. 2328 displaying 
a black point), then the currently selected range of cells is reshaped to 
correspond to the whole scalable template instance to which the currently 
selected cell belongs. 

Once the reshape is done, a conventional cut operation is performed from the 
reshaped range of cells onto the memory clipboard, when the cut mode is 
either "range'' or "instance". In the case the cut mode is equal to "element*', a 
conventional copy operation is first perfonned from the reshaped range of 
cells onto the memory clipboard, and then all the "IN" cells within this 
reshaped range of cells are updated with a void content. Then the Scalable 
Template Instance Cut l\/lanager Dialog Box 2320 is closed to complete the 
processing of the Scalable Template Instance Cut command! . . 

d. The spreadsheet user then selects another range of cells of his/her choice 
by using conventional means, such as but not limited to the pointing device 
105 or the keyboard 104. 

e. Scalable Template Instance Paste 

Then the spreadsheet user invokes thanks to conventional means available in 
spreadsheet environment, such as (but not limited to) 

• dedicated push-buttons, 

• keyboard entry short cuts, 

• menu or sub-menu entries, 

an original specific command called "Scalable Template Instance PasteT 
which pastes the content of the clipboard onto the currently selected cell. 

When the Scalable Template Instance Paste command is invoked, the first 
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• the overlap of the currently selected range of cells with existing scalable 
template instance(s), 

• the mode of cut, and 

• the presence of any existing critical scalable template Instance which 
would be corrupted due to the cut operation. 

The possibility to perform or not the cut operation according to the cut mode 
specified by one of the three option buttons 2330, 2329, and 2328, is 
reflected by several label boxes, taking the values *Ves" or "no", which are part 
of the Scalable Template Instance Cut Manager Dialog Box 2320. 
The two label boxes 2332 and 2333 reflect for the cut mode "range" if the cut 
operation may lead to con-upt any existing critical scalable template instance 
(label box 2332), or may lead to conupt any other existing scalable template 
instance (label box 2333). As soon as the value 'Ves" is tal<en by the 2332 
label box, the label box 2325 located in the "Possible' column 2324 takes the 
value "no" reflecting that the cut mode "range" is not possible. 
The label box 2326 takes the value \es" as soon as the currently selected 
cell is located within an existing scalable template instance, so that the 
"element" cut mode is possible. 

The label box 2327 takes the value *Ves" as soon as the cun-ently selected 
cell is located within an existing scalable template instance, so that the 
"instance" cut mode Is possible. As soon as the value "no" is taken by the 

2325 label box when the option button 2330 displays a black point, or by the 

2326 label box when the option button 23i29 displays a black point, or by the 

2327 label box when the option button 2328 displays a black point, then the 
cut operation is considered as impossible, so that the "Cuf push-button 2323 
gets disabled. 

Reversely, if the value "yes" is displayed instead of the value "no", then the cut 
operation is possible, so that the "Caf push-button 2323 get enabled. When 
the "Cuf push-button 2323 is clicked with the pointing device 105 by the 
spreadsheet user, the selected cut mode is used to determine how to 
reshape the currently selected range of cells. 

If the selected cut mode is the "range" mode (option button 2330 displaying a 
black point), then the cun-ently selected range of cells is kept as is. 
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First the name of the scalable template that the scalable template instance to 
which the cun-ently selected cell belongs, abides by, is displayed in the label 
box 2331 (if such a scalable template instance does not exist, then the label 
box 2331 displays the reserved name "none^. 

Second the cut mode is specified by the presence of a black point within one 
of the three option buttons 

• "Cut as a range of cell^ 2330, 

• "Cuf as e/emenf^ 2329, and 

• "Cut as an lnstanc€i'..2328, 

respectively corresponding to the cut modes "range", "element" and "instance". 
If the spreadsheet user wishes to change the default cut mode which is 
"range" in a prefen-ed embodiment of the present invention, or a previously 
changed cut mode, then he/she uses the pointing device 105 to cliqk on one 
of the three option buttons "Cut as a range ofcell^ 2330, "Cut as element^ 
2329, and "Cut as an Instance 2328 which will display alone a black point 
specifying the new selected cut mode. 

Third the push-button "Cancel' 2322 or the closing-window push-button 2321 
allow to close the Scalable Template Instance Cut Managei- Dialog Box 2320 
without further action. By clicking with the pointing device 105 on one of these 
two push-buttons 2321 and 2322, the Scalable Template Instance Cut 
Manager Dialog Box 2320 Is closed and the cut operation is aborted. 

Fourth the push-button "Cuf 2323, when clicked with the pointing device 105 
by the spreadsheet user, is the trigger launching the operation of cut. This 
push-button "Cuf 2323 is enabled (meaning that the method recognises the 
click event with the pointing device 105 on this push-button "Cuf 2323) when 
the cut operation is possible. The fact that this cut operation is possible or not 
depends on different factors: 

• the position of the cun-ently selected cell within an existing scalable 
template instance, 
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When the Scalable Template Instance Cut command is invoked, a test is 
first performed to determine if the currently selected range of cells overiaps or 
not (totally or partially) one or several existing scalable template instances. 
If It Is not the case, then a conventional Cut operation is perfomied from the 
cun^ently selected range of cells onto the clipboard. 

If it is the case, then a second test is perfomied to detenmlne if the currently 
selected cell belongs or not to an existing scalable template instance. 
If it is not the case, then a conventional cut operation will be possible, at the 
cost of conrupting the existing scalable template instances which overfap with 
the cun-ently selected range of cells. 

If it is the case, then three different modes of cut become possible. 
The first cut mode is the "range" mode which corresponds to the conventional 
cut operation where the currently selected range of cells is cut onto the 
clipboard. With this first mode, any existing scalable template instance 
overlapping with the cut range of cells will be corrupted. 
The second cut mode is the "element" mode where the range of cells to be cut 
onto the clipboard corresponds to the elements and meta-elements which on 
one side are part of the scalable template jnstarice to which the currently 
selected cell belongs, and which on the other side occupy the rows of the 
currently selected range of cells: With this second mode, the aforementioned 
elements and meta-elements are in fact copied onto the clipboard, and then 
only their cells specified as "IN" cells are changed with empty content. 
The third cut mode is the "instance" mode where the range of cells to be cut 
onto the clipboard conresponds to the whole scalable template instance to 
which the currently selected cell belongs. With this third mode, the scalable 
template instance to which the currently selected cell belongs is in fact moved 
to the clipboard, and is thus no longer considered as an existing scalable 
template instance. 

To detenmine which cut mode to use, the Scalable Template Instance Cut 
Manager Dialog Box 2320 is displayed on the display device 106, as 
illustrated by FIG 23B. This Scalable Template Instance Cut Manager Dialog 
Box 2320 contains some pieces of infomiation which relate to the cut 
operation. 
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2300 without further action. By clicking with the pointing device 105 on one of 
these two push-buttons 2301 and 23D2, the Scalable Template Instance 
Copy Manager Dialog Box 2300 is closed and the copy operation is aborted. 

5 Fourth the push-button "Cop/ 2303, when clicked, with the pointing device 

105 by the spreadsheet user, is the trigger launching the operation of copy. 
This push-button "Cop/ 2303 is always enabled (meaning that the method 
recognises the click event with the pointing device 105 on this push-button 
"Cop/ 2303) as the copy operation is always possible. This is reflected by 

10 the three label bpxes 2305, 2306 and 2307 in the "Possible columns 2304, 

which always display the value "yes" to reflect that the three different copy 
modes are always available. When the push-button "Cop/ 2303 is clicked 
with the pointing device 105 by the spreadsheet user, the selected copy 
mode is used to detemnine how to reshape the currently selected range of 

15 cells. 

If the selected copy mode is the "range" mode (option button 2310 displaying 
a black point), then the currently selected range of cells is kept as is. 
If the selected copy mode is the "element" mode (option button 2309 
displaying a black point), then the currently selected range of cells is 
20 reshaped to correspond to the elements and meta-elements which on one 

side are part of the scalable template instance to which the currently selected ■'. 
cell belongs, and which on the other side occupy the rows of the currently 
selected range of cells. 

If the selected copy mode is the "instance" mode (option button 2308 
25 displaying a black point), then the currently selected range of cells is 

reshaped to correspond to the whole scalable template instance to which the 
currently selected cell belongs. 

Once the reshape is done, a conventional copy operation is performed from 
the reshaped range of cells onto the memory clipboard. Then the Scalable 
30 Template Instance Copy Manager Dialog Bpx 2300 is closed to complete the 
processing of the Scalable Template Instance Copy command. 

• c. Scalable Template instance Cut 
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The second copy mode is the "ELEMENf * mode where the range of cells to be 
copied onto the clipboard coaesponds to the elements and meta-elements 
which on one side are part of the scalable template instance to which the 
currently selected cell belongs, and which on the other side occupy the rows 
of the currently selected range of cells. 

The third copy mode is the "instance" mode where the range of cells to be 
copied onto the clipboard corresponds to the whole scalable template 
instance to which the currently selected cell belongs. 

To detemnine which copy mode to use, the Scalable Template Instance Copy 
Manager Dialog Box 2300 is displayed on the display device 106, as 
illustrated by FIG 23A. This Scalable Template Instance Copy Manager 
Dialog Box 2300 contains some pieces of infomnation which relate to the copy 
operation. 

First the name of the scalable template that the scalable template instance to 
which the currently selected cell belongs, abides by, is displayed in the label 
box 2311. 

Second the copy mode is specified by the presence of a black point within 
one of the three option buttons 

• ''Copy as a range of cell^ 231 0, 

• "Copy as e/emenfs?' 2309, and 

• *'Copy as an Instance' 230B, 

respectively con-esponding to the copy modes "range", "element" and 
"instance". If the spreadsheet user wishes to change the default copy mode 
which is "range" in a preferred embodiment of the present invention, or a 
previously changed copy mode, then he/she uses the pointing device 105 to 
click on one of the three option buttons "Copy as a range of cell^ 2310, 
"Copy as elemental' 2309, and "Copy as an Instanced* 2308 which will display 
alone a black point specifying the new selected copy mode. 

Third the push-button "Cancer 2302 or the closing-window push-button 2301 
allow to close the Scalable Template Instance Copy Manager Dialog Box 
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The fifth operation occurs when the spreadsheet user decides, based on his or 
her own criteria not detailed here, to perfomn a copy-and-paste or a 
cut-and-paste operation with a given scalable template instance. In a prefen^ed 
embodiment of the present invention, this operation comprises the following 
5 steps: 

• a. The spreadsheet user first selects a range of cells of his/her choice by 
using conventional means, such as but not limited to the pointing device 105 
or the keyboard 104. 

10 • b. Scalable Template instance Copy 

Then the spreadsheet user invokes thanks to conventional means available in 
spreadsheet environment, such as (but not limited to) 
. • dedicated push-buttons, 
• keyboard entry short cuts, 

15 • menu or sub-menu entries, 

one of the two original commands called ""Scalable Template Instance 
Cop/, or "Scalable Template Instance Cuf in order to copy or cut onto the 
clipboard available as part of the memory storage 102 the selected range of 
cells, or any elements or meta-elements contained in the selected range of 

20 cells or even the whole scalable template instance containing the currently 

selected cell. 

When the Scalable Template Instance Copy command is invoked, a test is 

first performed to detemriine whether the currently selected cell belongs or not 
25 , to an existing scalable template instance. 

If it is not the case, then a conventional Copy operation is perfonned from the 
. currently selected range of cells onto the clipboard. 

If it is the case, then three different modes of copy become possible. 

The first copy mode is the "range" mode which corresponds to the 
30. conventional copy operation where the currently selected range of cells is 

copied onto the clipboard. 
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destination is performed cell after cell, starting with the leftmost cell, and up to 
the rightmost one. For a given relative cell position within the corresponding 
ranges of cells (element or meta-element and illustrative rang of cells 654), 
the copy-paste operation by content is perfonned unless the two following 
S conditions are fulfilled: 

• both in its previous and updated profile definition, the current cell is 
considered as an ''IN" cell, and 

• the content of the cell in the element or meta-element is different from the 
content of the cell In the previous profile definition. 

10 These two tests are necessary to avoid the ovenvritting of an "IN" cell which 

content was already filled by the spreadsheet user. Indeed in siich a case, 
the default cell content, as specified in the previous profile definition, has 
been replaced by a user-speclfed content which must not be lost! As a result, 
the updated profile definition is reflected in cells of elements or 

15 meta-elements In the following situations: 

• the cell is defined in the updated destination as an "OUT" cell, or 

• the destination of the cell is updated and the cell becomes an "IN" cell 
while the cell was defined in the previous destination as an "OUT" cell, or 

• the destination is unchanged and the cell remains an "IN" cell while the 
20 cell content matches the content defined in the previous profile definition; 

When every cell of every refreshed element or meta-element of every 
refreshed instance has been refreshed, the refresh operation is completed, 
and an information message is displayed on the display device 106, as 
25 illustrated with the dialog box 2210 described within the FIG 22B. This dialog 

box 2210 contains a text window 2213 specifying the information message. 
The spreadsheet user can close this dialog box 2210. by clicking with the 
pointing device 105 on the "O/C push button 2212 or on the closing-window 
push button 2211. 

30 • 5. Fifth Operation : Copy/Cut and Paste a Scalable Template Instance 
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If the updated object (either an element fomat, or a meta-element fomiat, or 
an element profile or a meta-element profile) Is not referenced In at least a 
scalable template that at least one existing scalable template instance abides 
by, then a warning message is displayed on the display device 106, as 
illustrated with the dialog box 2200 described within the FIG 22A. This dialog 
box 2200 contains a text window 2203 specifying the warning message. The 
spreadsheet user can close this dialog box 2200 by clicking with the pointing 
device 105 on the "OK' push button 2202 or on the closing-window push 
button 2201. 

If the updated object is referenced in at least one scalable template that at 
least one existing scalable template instance abides by, then the Refresh 
operation does effectively take place. This operation consists: 

• first in identifying each existing scalable template instance which abides 
by a scalable template which references the updated object, 

• then in identifying within each found scalable template instance all 
elements or meta-eiements which depend on the updated object, and 

• finally in refreshing each identified element or meta-element according to 
the change of the updated object. This element or meta-element Refresh 
operation depends on the nature of the updated object. 

If the updated object is an element fomiat or a meta-element format, then the 
Refresh operation of a given element or meta-element consists in performing 
a conventional copy-paste operation by attribute (the content and the 
destination (IN" cell vs "OUr cell) being kept untouched) from the new 
object illustrative range of cells 634 onto the given element or meta-element. 

If the updated object is an element profile or a meta-element profile, then the 
Refresh operation of a given element or meta-element consists in performing 
a conventional copy-paste operation by content and by destination ("IN" cell 
vs "OUT cell), the attributes being kept untouched, from each cell of the new 
object illustrative range of cells 654 onto each corresponding cell of the given 
element or meta-element. This copy-paste operation by content and 
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• existing element formats, or 

• meta-element fomiats, or 

• element profiles, or 

• meta-element profiles, 

so that the new definition gets automatically reflected in every scalable template 
instance abiding by an updated scalable template. In a preferred embodiment of 
the present invention, this operation comprises the following steps: 

• a. The spreadsheet user first invokes thanks to convenjtional means available 
in spreadsheet environment, such as (but not limited to) 

• dedicated push-buttons, 

• keyboard entry short cuts, 

• menu or sub-menu entries, 

the original command called "Scalable Template Managef\ followed by one 
of the original commands called ""Element Format Editof\ or "Element 
Profile Editor" in order to start updating either an existing element fonnat, or 
an existing meta-element fomiat, or an existing element profile, or an existing 
meta-element profile. This initial step corresponds to the first step of the first . 
operation of this scenario, followed by the second, or third step of the first 
operation of this scenario. 

• b. Scalable Template Refresh Manager 

Then the spreadsheet user invokes thanks to conventional means available in 
spreadsheet environment, such as (but not limited to) 
. • dedicated push-buttons, 

• keyboard entry short cuts, 

• menu or sub-menu entries, 

an original specific command called Scalable Template Refresh Manager^ 
which identifies if at least one existing scalable template instance abides by 
the object updated during the. previous step, and then retrofits the update 
onto the scalable template instances. 
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Second any data previously located within the range of cells STDM^range 
2002 is now pushed away from the current sheet 2030. 
As previously explained, If one of the corrupted existing instance is a critical 
instance, then the deletion operation would be considered as impossible, so 
5 that the ""Delete push-button 1923 remains disabled. 

Othen/viise the deletion operation is perfonned, and any existing impacted 
scalable template instance . will, no longer be .considered as a scalable 
template instance. . 

10 Referring now to FIG 20E, the "vertical delete by range" mode is illustrated by 

the updated current sheet 2040, resulting from the column deletion within 
range of the previously selected range of cells STDM^range 2002, so that the 
range of cells STDM^right_range moves from the former position 2003 to the 
new position 2041, and so that a new range of void cells 2042 is iritroduced 

15 on the right of the new position of the range of cells STDM^righLrange 2041 . 

The range move may have some impact on existing instances. 
First any instance like the STDM^horizontaLshearedJnstance 2009 (which 
partially or totally overlapped the range of cells made, by the concatenation of 
the two ranges of cells STDM^range 2002 and STDM_right_range 2041 ) are 

20. sheared into two pieces (possibly void): the top piece 2044 and the bottom 
piece 2043. 

Second any data previously located within the range of cells STDM_range 
2002 is now pushed away from the current sheet 2040. 
As previously explained, if one of the corrupted existing instance is a critical 
25 instance, then the deletion operation would be considered as impossible, so 

that the "Detefe" push-button 1923 remains disabled. 
OthenA^ise the deletion operation is perfonned, and any existing impacted 
scalable template instance will no longer be considered as a scalable 
template instance. 

30 • 4. Fourth Operation : Definition Updates of Eiement Formats or Profiles 

The fourth operation occurs when the spreadsheet user decides, based on his or 
her own criteria not detailed here, to update the definition of 
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position 2022, as well as the two other ranges of cells 2021 and 2023 
occupying the same columns, and so that a new range of void cells 2026 is 
appended at the right of the current sheet 2020. The deletion of the columns 
may have some impact on existing instances. 

First any instance like the STDM^verticaLcutJnstance 2007 or the 
STDM^verticaLshearedJnstance 2008 (which overlapped partially or totally 
the columns occupied by the cun'ently selected range of cells 2002) is 
reduced to a remaining piece (potentially void): the left piece 2024 which was 
located on the left of the deleted columns and the right piece 2025 which was 
located on the right of the deleted columns. 

Second any data previously located within the ranges of cells STDM_range 
2002, STDM_bottom_range 2004 and STDMJop^range 2006 is now pushed 
away from the current sheet 2020. 

As previously explained, if one of the conupted existing instance is a critical 
instance, then the deletion operation would be considered as impossible, so 
that the "De/efe" push-button 1923 remains disabled. 
Othenwise the deletion operation is perfomned, and any existing impacted 
scalable template Instance will no longer be considered as a scalable 
template instance. 

Refening now to FIG 20D, the "horizontal delete by range" mode is illustrated 
by the updated current sheet 2030, resulting from the row deletion within 
range of the previously selected range of cells STDM^range 2002, so that the 
range of cells STDM_bottom_range moves from the fomrier position 2004 to 
the new position 2031, and so that a new range of void cells 2032 is 
introduced below the new position of the range of cells STDM_bottom_range 
2031 . The range move may have some impact on existing instances.- 
First any instance like the STDM_verticaLshearedJn$tance 2008 (which 
partially or totally overlapped the range of cells made by the concatenation of 
the ranges of cells STDM^range 2002 and STDM_bottom_range 2004) are 
sheared into two pieces (possibly void): the left piece 2033 and the right piece 
2034. 
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If one of the corrupted existing scalable template instances is a critical 
instance, then the deletion operation would be considered as impossible, so 
that the ''Deleter push-button 1923 remains disabled. 
OthenA/ise the deletion operation is perfomned, and any existing impacted: 
scalable template instance will no longer be considered as a scalable 
template instance. 

Referring now to FIG 20B, the "horizontal delete" mode is illustrated by the 
updated current sheet 2010, resulting from the deletion of the rows occupied 
by the currently selected range of cells STDM^range 2002, so that the . 
STDM_bottom_range moves from the fomier position 2004 to the new 
position 2012, as well as the two other ranges of cells 2011 and 2013 
occupying the same rows, and so that a new range of void cells 2015 is 
appended at the bottom of the current sheet 2010. The deletion of the rows 
may have some impact on existing instances. 

First any instance like the STDM^horizontaLshearedJnstance 2009 (which 
overlapped partially or totally the rows occupied by the currently selected 
range of cells 2002) is reduced to a remaining piece (potentially void): the 
piece 201 4 which was located below the deleted rows. 
Second any data previously located within the ranges of cells STDM^range 
2002, STDMJeft_range 2005 and STDM_right_range 2003 is now. pushed 
away from the current sheet 2010. 

As previously explained, if one of the corrupted existing instance is a critical 
instance, then the deletion operation would be considered as impossible, sq 
that the "Deleter push-button 1923 remains disabled. 
OthenA/ise the deletion operation is perfomied, and any existing impacted 
scalable template instance will no longer be considered as a scalable 
template instance. 

Referring now to FIG 20C, the ^Vertical delete" mode is illustrated by the 
updated current sheet 2020, resulting from the deletion of the columns 
occupied by the currently selected range of cells STDM^range 2002, so that 
the STDM_right_range moves from the former position 2003 to the new 
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2000 before the deletion operation is triggered Within this current sheet, the 
currently selected cell 2001 Is part of the currently selected range of cells 
STDM^range 2002. Four other ranges of cells can now be identified within 
the cun-ent sheet 2000: 
5 • the range of cells STDM_right_range 2003 which is located on the same 

rows as the range of cells STDM^range 2002, but in the columns on its 

right; 

• the range of cells STDM_bottom_range 2004 which is located on the 
same columns than the range of cells STDM^range 2002, but in the rows 

10 bellow it; 

• the range of cells STDMJeft^range 2005 which is located on the same 
rows as the range of cells STDM^range 2002, but in the columns on its 
left; and 

• the range of cells STDM_top_range 2006 which is located on the same 
15 columns than the range of cells STDM^range 2002, but in the rows above 

• it. ■ 

Finally the FIG 20A also shows 3 existing scalable template instances: 

• STDM_vertical_cutJnstance 2007, . . 

• STDM^verticaLshearedJnstance 200B, 
20 • STDM_horizontaLshearedJnstance 2009. 

The "content delete" mode consists in clearing the content of every individual 
cell belonging to the currently selected range of cells STDM^range 2002. This 
range of cells STDM^range 2002 may partially or totally overlap one or a 
25 plurality of existing scalable template instances, so that the resulting 

. intersection is constituted by element or meta-element cells which can be 
either defined as "IN" cells or as "OUr cells. 

If this intersection comprises only "IN" cells, then clearing their content does 
not corrupt at all the scalable template instances they belong to. 
30 Reversely if this intersection comprises "OUT" cells, the clearing their content 

corrupts the scalable template instances they belong to. 
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push-button ''Delete 1923) when the deletion operation is possible. The fact 
that this deletion operation is possible or not depends on different factors: 

• the position of the currently selected cell within the current sheet of the 
electronic spreadsheet, 

• the size of the curently selected range of cells, 

• the mode of deletion, 

• the presence of any existing critical scalable template instance which 
would be conupted due to the deletion operation. 

The possibility to perform or not the deletion according to the mode of 
deletion specified by one of the five option buttons 1925, 1926, 1927, 1928 
and 1930, is reflected by several label boxes, taking the values "yes" or "no", 
which are part of the Scalable Template Delete Manager Dialog Box 1920: 
the set of 15 label boxes 1924 which are organised as a matrix of 5 rows by 3 
columns and which reflect for each possible mode of deletion (one per row) if 
the deletion operation may lead to corrupt any existing critical scalable 
teniplate instance (first column), or may lead to conupt any other existing 
scalable template instance or may lead to loose any existing data present in 
one or several spreadsheet cells. 

As soon as the value *Ves" is taken by the 1924 label box located at the 
intersection of the leftmost column and of the row corresponding to the 
selected mode of deletion, then the deletion operation is considered ais 
impossible, so that the "Deleter push-button 1923 get disabled. 
Reversely, if the value ''no" is displayed in this label box, then the. deletion 
operation is possible, so that the "De/efe^ push-button 1923 get enabled. 
When clicked with the pointing device 105 by the spreadsheet user, the 
deletion operation is performed, and then the Scalable Template Delete 
Manager Dialog Box 1920 is closed. 

The way the deletion operation may corrupt an existing scalable template 
instance or may lead to loose any data present in a cell is illustrated for each 
mode of deletion by the FIG 20A, 20B, 20C, 20D and 20E. 

Referring first to the FIG 20A, one can see an illustration of the current sheet 
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The Scalable Template Delete Manager Dialog Box 1920 contains some 
pieces of information wtiich relate to the deletion operation in the case where 
the cunently selected cell is outside any existing scalable template instance. 

First a label box 1929 filled with the reserved value "None" indicates that the 
cunrently selected cell does not belong to any existing scalable template 
instance. 

Second the mode of the deletion is specified by the presence of a black point 
within one of the five option buttons: 

• "Content Delete 1930, 

• 'Horizontal Deleter 

• "Horizontal Delete by Rang^ 1 927, 

• "\/e;f/ca/De/efe^ 1926 and 

• "Vertical Delete by Rangd"l925. 

If the spreadsheet user wishes to change the default mode of deletion which 
is "Content Deleter in a preferred embodiment of the present Invention, or a 
previously changed mode of deletion, then he/she uses the pointing device 
105 to click on one of the five option buttons "Content Delete 1930, 
"Horizontal Delete 1928, "Horizontal Delete byRang^ 1927, "Vertical Delete 
1926 and "Vertical Delete by RangeT 1925 which will display alone a black 
point specifying the new selected mode of deletion. 

Third the push-button "Cancer 1922 or the closing-window push-button 1921 
allow to close the Scalable Template Delete Manager Dialog Box 1920 
without further action. By clicking with the pointing device 105 on one of these 
two push-buttons 1921 and 1922, the Scalable Template Delete Manager 
Dialog Box 1920 is closed and the deletion operation is aborted. 

Fourth the push-button "Deleter 1923, when first enabled and second clicked 
with the pointing device 105 by the spreadsheet user, is the trigger launching 
the operation of deletion. This push-button "Delete ^9Z3 is enabled (meaning 
that the method recognises the click event with the pointing device on this 
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Sixth the push-button "Deletd' 1903, when first enabled and second clicked 
with the pointing device 105 by the spreadsheet user, is the trigger launching 
the operation of scalable template instance deletion. This push-button 
Delete 1903 is enabled (meaning that the method recognises the click event 
with the pointing device on this push-button "Deleter 1903) when the deletion 
operation is possible. The fact that this scalable template deletion operation is 
possible or not depends on different factors: 

• the position of the currently selected cell within the current scalable 
template instance, 

• the size of the current scalable template instance and of the currently 
selected range of cells, 

• the mode of deletion. 

When the deletion mode is equal to "delete_IN_fields_in_selected_range" or 
"delete J N_FiELDs_iN_sELECTED_Rows" or "delete_selected_instance", then , the 
deletion operation is always possible, so that .the "De/efe" push-button 1903 
remains enabled. 

When the deletion mode is equal to "delete^selected^elements", then the 
deletion operation Is only possible if two conditions, are met: 

• first the cun^ently selected range of cells must be entirely locatfed within the 
body part of the cunrent scalable template, as specified by the "Selection . 
outside bodf text box 1904 which can takes the values "yes" and "no"; 

• second the number of deleted elements must result in a new number of 
elements remaining above the minimum number of elements in the 
current scalable template instance, as specified in the "Selection too bi^' 
text box 1907 which can takes the values "yes" and "no". 

Thus when the "delete_selected_elements" option button 1912 is selected, the 
"Delete" push-button 1903 is enabled if and only if the two text boxes 1904 
and 1907 display the value "no". When clicked with the pointing device 105 by 
the spreadsheet user, the deletion operation is performed, and then the 
Scalable Template Delete Manager Dialog Box 1900 is closed. 
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Third the mode of the deletion is specified by the presence of a black point 
within one of the four option buttons: 

• "deleteJN^fieldsJn^selected^rang^'IQOS; 
"deleteJN_field$Jn_selected^row^' 1906; 

• "c/e/efe_setecfedLefemenfs^ 1912; and 

• "delete^selectedjnstancd' 1 91 3. 

If the spreadsheet user wishes to change the default mode of deletion which 
is "delete_IN_fieldsJn_selected_rang^ or a previously changed mode of 
deletion, then he/she uses the pointing device 105 to click on one of the four 
option buttons; 

• ''delete_IN_fieldsJn_selGcted_range"190S, 

• "deleteJN_fieldsJn_selected_rowsr 1906, 

• ''delete_selected_element^ .1 91 2, and .. 

• "delete_selectedjndtanc€i' ^9^3, 

which will display alone a black point specifying the new selected mode of 
deletion. 

Fourth the check box 1910 allows the spreadsheet user to visualise and 
possibly to change if the cun-ent scalable template instance is considered or 
not as a "Criticar instance. If and only if the check box 1910 displays a check 
mark, then the current scalable tiemplate instance is a critical one. By clicking 
with the pointing device 105 on this check box 1910, the spreadsheet user 
can swap between a "Cnf/car and not ""CriticaP instance, which is reflected by 
the presence or absence of a check mark within this same check box 1910. 

Fifth the push-button ''Cancer 1902 or the closing-window push-button 1901 
allow to close the Scalable Template Delete Manager Dialog Box 1900 
without further action. By clicking with the pointing device 105 on one of these 
two push-buttons 1901 and 1902, the Scalable Template Delete Manager 
Dialog Box 1900 is closed and the scalable template deletion operation is 
aborted. 
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• the mode "vertical_delete" where are removed the whole columns 
containing the currently selected range of cells, 

• the mode "vertical_delete_by_range" where the range of cells located on 
the bottom of the cun-ently selected range of cells is shifted up to 

. ovenA^ritte the currently selected range of ceils. 
If the cunrently selected cell is found outside a scalable template instance and 
If the deletion operation cannot cormpt any existing scalable template 
instance, then the conventional means interfacing the spreadsheet user for 
initiating a deletion operation are used. 

The Scalable Template Delete Manager Dialog Box. 1900 contains some 
pieces of Infomnation which relate to the deletion operation in the case where 
the currently selected cell is within an existing scalable template instance. 

First the name of the scalable template that the current scalable template 
instance abides by, is displayed in a label box 1911. 

Second the number of elements to be deleted is shown in a text box 1908. 
This number takes as initial value the number of etemianfrows contaiinecl in 
the currently selected range of cells. If the spreadsheet user wished to delete 
within the current scalable template instance another nu.hiber of . elements, 
then he/she will have to click with the pointing device 105 on the upper or 
lower side of the spin-button 1909 to either increase or decrease the number 
of elements to be deleted. This number of deleted elements will vary within a 
range whose boundaries are delimited by ensuring that the difference of the 
number of already existing elements with the number of deleted elements 
remains within the minimum and maximum number of elements, as specified 
within the definition of the scalable template (fields "Min Element #' 725 and 
"Max Element r 726 within a record 721 of the STT table 720 whose "A/am^' 
field 722 matches the name displayed in the label box 1911) and is displayed, 
after possible update, in the text box 1908, whereas the currently selected 
range of cells is updated accordingly by containing as many element rows as 
the number of inserted elements. 
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Then the deletion operation continues by displaying on the display device 106 
the Scalable Template Delete Manager Dialog Box 1900, as illustrated by FIG 
19A. 

If the cun^ently selected cell is found outside a scalable template instance, 
thdn a conventional deletion operation may have some side effects on 
existing scalable template instances. It is therefore needed to dynamically 
determine if such a deletion operation may lead to corrupt any existing 
scalable template Instance. Such a cormption can take different forms, but 
always correspond to a situation where a scalable template iristance does no 
longer abide by Its associated scalable template. A typical scalable template 
instance corruption case is for instance the deletion of a row comprising a 
meta-element belonging to an existing scalable template instance. In such a 
case, either the header or the footer part of this existing scalable template 
instance is conxipted, so that the scalable template instance, as a whole, is 
itself corrupted. 

Once the method has dynamically detemnined that a meta-element, or an 
element, of any existing scalable template instance gets corrupted as a result 
of the deletion operation, then the spreadsheet user is infomied about thl§ 
situation, so that he/she can either cancel the deletion operation, or decide to 
pursue it according to the mode which minimizes the negative side effects of 
the deletion operation. For this purpose, this dynamic management of 
meta-element and/or element corruption displays on the display device 106. 
the Scalable Template Delete Manager Dialog Box 1920, as illustrated by FIG 
1 9B, which offers five different modes.of deletion: 

• the mode "content_delete" where Is cleared the content of all Individual 
cells within the currently selected range of cells, 

• the mode "horeontal^delete" where are removed the whole rows 
containing the currently selected range of cells, 

• the mode "hori20ntal_delete_by_range" where the range of cells located 
on the right of the currently selected range of cells is shifted left to 
ovenwrite the currently selected range of cells, . 
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• if the user action is a click on the upper part of the spin button 1609, then 
control is given to step 1522; 

• if the user action is a click on the lower part of the spin button 1609, then 
control is given to step 1541; 

• if the user action is a click on the "CnY/ca/' check box 1610, then control is 
given to step 1523; 

• if the user action is a click on one of the option buttons 1606, or 1605, then 
control is given to step 1524; 

V if the user action is a click on the Cancer push-button 1602, or on the 
closing-window push-button 1 601 , then control is given to step 1 521 . 

At step 1513, the local variable STIM_sheet_width 1741 is initialised with the 
total number of columns in the current sheet 1740. Then another local variable 
STIM_sheeLheight 1742 is initialised with the total number of rows in the current 
sheet 1740. Then another local variable STIM^mode is initialised with the value 
HORizoNTALjNSERT. Then the number of rows and of columns of the cun^ently 
selected range of cells STIM^range 1748 is represented respectively by the local 
variables STIM^height 1746 and STIM^width 1745. Then the position of the 
currently selected cell 1747 is first represented by the local variables 
STIM_offseLwidth 1743 and STIM^offsetJieight 1744 con-esponding 
respectively to the number of columns and of rows between the top left cell of the 
current sheet 1740 and the currently selected cell 1747. Then the range of cells 
STIM_verticaLflushed_range 1752 is determined as the range of cells sharing 
the same columns as STIM^range 1748, and occupying the STlMJheight 1746 
bottom columns of the current sheet 1740. Then the range of cells 
' STIM^verticaLkepCrange ^TSI is detemained as the range, of cells sharing the 
same columns as STIM_range 1748, and occupying the. rows located between 
those of STIM^range 1743 and STIM_^verticaUlushed_range 1752.. Then the 
range of cells STIMJhorizontalJIushed^range 1750 is detemiined as the range 
of cells sharing the same rows as STIM^range 1748, and occupying the 
STIM^width 1745 rightmost columns of the current sheet 1740. Then the range 
of cells STIM_horizontaLkepLrange 1749 Is detemiined as the range of cells 
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sharing the same rows as STIM^range 1748, and occupying the columns located 
between those of STIM_range 1748 and STIMJhorizontalJIushedjrange 1750. 

• At step 1514, several tests are perfomned to evaluate the potential impact of the 
insertion, according to four possible insertion modes, on any already existing 
5 scalable template instance or data. These tests require to parse the STIT table 
, 750, and to visit each record 751 to leam the address {"Address field 752) and 
the importance {"Criticar field 755) of every already defined scalable template 
instance. These tests evaluate either if two given ranges of cells partjally overlap 
(meaning that there exist in the first range of cells at least one cell belonging to 
10 the second range of cells and at least one cell not belonging to the second range 
of cells) or if a first given range of cells is included within a second given range of 
cells (meaning that every cell belonging to the first range of cells belongs too to 
the second range of cells). Different conventional range comparison techniques 
can be used for evaluating either range partial overlapping or range inclusion, 
15 without departing from the spirit of the present invention; they will not be 
described in the preferred embodiment of the present invention. 

First the HORizoNTALjNSEm" mode of insertion is investigated. 

• If there exists at least one existing scalable template instance whose "Cnf/ca/' 
20 field 755 takes the value "yes" and which partially overlaps the range of cells. 

made of the entire row where is located the currently selected cell 1747, or. 
which partially overlaps the range of cells constituted by the last bottom. 
STIMJieight 1746 rows, or which is included in the range of cells constituted 
by the last bottom STIMJielght 1746 rows, then the local test variable 
25 STIMJhorizontaLcntical takes the value "yes"; othenfl^ise the local test variable 
STIM_horizontal_critical takes the value "no". 

• If there exists at least one existing scalable template instance whose "Cnf/car 
field 755 takes the value "no" and which partially overlaps the range of cells 
made of the entire row where is located the currently selected cell 1747, or 

30 which partially overlaps the range of cells constituted by the last bottom 
STIMJheight 1746 rows, or which is included in the range of cells constituted 
by the last bottom STIMJheight 1746 rows, then the local test variable 
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STIM_horizontaLother takes the value "yes"; otherwise the local test variable 
STIM_horizontaLother \akes the value "no". 

• If all the cells within the range of cells constituted by the last bottom 
STIM_height 1746 rows are empty (containing none data), then the local test 

5 variable STIM_horizontaLdata takes the value "no"; othenA^ise the local test 
variable STIM^horizontaLdata takes the value "yes". 

Second the hor!Zontaljnsert_by_range mode of Insertion is investigated. 

• If there exists at least one existing scalable template instance whose "Criticar 
10 field 755 takes the value "yes" and which partially overiaps the range of cells 

constituted by the concatenation of the two ranges of cells STIMjrange 1748 
and STIM_yerticaLkept_range 1751, or which partially overiaps the range of 
cells STIM_verticaUlushed_range 1752. or which is included in the range of 
cells STIM_verticaUlushed_range 1752,. then the local test variable 
15 STIM_hdrizontaLrange_critical takes the value \es"; othenA^ise the local test 

variable ST/M_^o/7zonfaLransfe_cr/Y/ca/ takes the value "no". 

• If there exists at least one existing scalable template instance whose ""Criticar 
field 755 takes the value "no" and which partially overiaps the range of cells 
constituted by the concatenation of the two ranges of cells STIMjrange 1748; 

20 and STIM_verticaLkept_range 1751, or which partially overiaps the range of 
cells STIM_verticaUlushed_range 1752, or which is included in the range of 
cells STIM_verticaUlushed_range 1752, then the local test variable 
STIMJhorizontaUange^other takes the value "yes"; othenwise the local test 
variable STIM_horizontaLrange_other takes the value "no". 

25 • If all the cells within the range of cells STIMj\/erticalJlushed_range 1752 are 
empty (containing none data), then the local test variable 
STIM_horizontal_range_data takes the value "no"; otherwise the local test 
variable STIM_horizontal_range_data takes the value "yes". 

30 Third the verticaljnsert mode of insertion is investigated. 

• If there exists at least one existing scalable template, instance whose ""Criticar 
field 755 takes the value "yes" and which partially overiaps the range of cells 
made of the entire column where is located the currently selected cell 1747, or 
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which partially overlaps the range of cells constituted by the last right 
STIM^width 1745 columns, or which is included in the range of cells 
constituted by the last right STIM_width 1745 columns, then the local test 
variable STIM^verticaLcritical \akes the value 'Ves"; othenwise the local test 
variable STIM_V0rticaLcritical\akes the value "no". 

• If there exists at least one existing scalable template instance whose ""Criticar 
field 755 takes the value "no" and which partially overiaps the range of cells 
made of the entire column where is located the currently selected cell 1747, or 
which partially overiaps the range of cells constituted by the last right 
STIM^width 1745 columns, or which is included in the range of cells 

. constituted by the last right STIM^width 1745 columns, then the local test 
variable STIM_verticaLother takes the value "yes"; otherwise the local test 
variable STIM_vertical_other takes the value "no". 

• If all the cells within the range of cells constituted by the last right STIM^width 
1745 columns are empty (containing none data), then the. local test variable 
STIMj/erticaLdata takes the value "no"; othenwise the Ibcial tejst variable 
Sr/yWLvert/caLdafa takes the value S'Es". 

Fourth the vertical_insert_by_range mode of insertion is investigated. 

• If there exists at least one existing scalable template instance whose ''Criticar 
field 755 takes the value "yes" and which partially overiaps the range of cells 
constituted by the concatenation of the two ranges of cells. STIM^range 1748 
and STIMJf)onzontaLkept_range 1749, or which partially overiaps the range 
of cells STIM_horizontaUlushed_range 1750, or which is included in the 
range of cells STIM_horizontaUlushed_range 1750, then the local test 
variable STIM_verticaLrange_criticaHakes the value "yes"; othemise the local 
test variable STIM_vertical_range_criticaHakes the value "no". 

• If there exists at least one existing scalable template instance whose "CriticaP 
field 755 takes the value "no" and which partially overiaps the range of cells 
constituted by the concatenation of the two ranges of cells STlM^range 1748 
and STlMJhorizontaLkept_range 1749, or which partially overiaps the range 
of cells STIMJhorizontaUlushed^range 1750, or which is included In the 
range of cells STIM_horizontaLflushed_range 1750, then the local test 
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variable STIM_verticaLrange_other takes the value "yes"; otherwise the local 
test variable STIM_verticaLrange_other takes the value "no". 
• If all the cells within the range of cells STIMJhorizontalJIushedjrange 1750 
are empty (containing none data), then the local test variable 
5 STIM_verticaLrange_clata takes the value "no"; othenvlse the local test 
variable STIM_verticaLrange_data takes the value "yes". 

• At step 1515, a test is perfomned to check the insertion impact on any existing 
scalable template , instance, according to the values assigned during the. step 
1514 to the local variables 

10 • STIM_horizontaLcritical, 

• STIM^hdhzontaLother, 

• STIM_horizontaLrange_critical, 

• STIM_horizontaLrange_other, 

• STIM^verticaLcritical, 
15 • STIM_verticaLother, 

• STIM_verticaLrange_critical, 

• STIM_vertical_range_other. 

If none of these local variables takes the Value "yes", then control is given to step 
1516; othenA^ise if at least one of these local variables takes the value "yes", then 
20 control is given to step 1517. 

• At step 1516, the conventional insertion method as used and defined in 
conventional electronic spreadsheet environments is triggerisd, and then coritrol 
is given back to the initial step 1501 for processing any future Scalable 
Template Instance Insertion Manager command. 

25 • At step 1517, the Scalable Template Insert Manager Dialog Box 1620 is 
displayed on the display device 106. The label box 1629 is initialised with the 
reserved value "None". The 12 label boxes 1624 are filled row after row, starting 
with the top row, from the left to the right, with the values of the following local 
variables in the following order: 

30 • STIM^horizontaLcritical, 
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• STIMJiorizontaLother, 

• STIM_horizontaLdata, 

• STlMJhorizontaLrangejcritical, 

• STIMJhorizontaLrange^other, 

• STIMJhorizontaLrange^data, 

• STIM_verticaLcritical, 

• STIM^verticaLother, 

• STIM^verticaLdata, 

• STIM_verticaLrange_critical, 

• STIM_verticaLrange_other, 

• STIM_verticaLrange_data. 

Then if the local variable STIM__mode takes the respective value 

HORIZONTALJNSERT, Or HORIZONTALJNSERT_BY_RANGE, Of VERTICAL_INSERT, Or 

vERTicAL_iNSERT_BY_RANGE, thQH the optiofi butlon 1628, Of 1627, or 1626, or 1625 
displays alone a black point. 

Finally the "Insert push-button 1623 is disabled as soon as one of the following 
local variables takes the value "yes": STIM^hotizontaLcritical (only taken" into 
account if the local variable STIM_mode is equal to horizontal_insert), 
STIM_verticaLcritical (only taken into account if the local variable STIM^mode is 
equal to verticaljnsert), STIM_horizontaLrange_critical {only taken into account 
if the local variable STtMjmode is equal to horizontaljnsert_by_range), 
STIM_verticaLrange_critical (only taken into account if the local variable 
STIM^mode is equal to vertical_insert_by_range); othenwise .this "Inserf 
push-button 1 623 is enabled. 

At step 1518, the method is waiting for any user action on the Scalable Template 
Insert Manager Dialog Box 1620. Such user action is typically resulting from a 
click with the pointing device 105, but take other similar fomis such as, but not 
limited to a specific combination of key on the keyboard 104, or any other similar 
means not further specified here. 



204 



\\f£\ i\'»tn-i AOOi 



PCT/EPOl/09483 



At step 1519, a user action on the Scalable Template Insert Manager Dialog Box 
1620 is detected. 

• If the user action is a click on the "/nse/f push-button 1623, then control is 
given to step 1526; 

• if the user action is a click on one of the option buttons 1628, or 1627, or 1626, 
or 1625, then control is given to step li520; 

if the user action is a click on the ''CanceP push-button 1622, or on the 
closing-window push-button 1 621 , then control is given to step 1521 . 

At step 1520, the local variable STIM_m6de takes the value horizontal^insert, or 

HORIZONTALJNSERT_BY_RANGE, Or VERTICAL_INSERT, Or VERTICAL_INSERT_BY_RANGE if the 

spreadsheet user has respectively clicked with the pointing device 105 on the 
option button 1628. or 1627, or 1626, or 1^25. Theii control is given to step 
1517. 

At step 1521, the Scalable Template Insert Manager Dialog Box 1600 or 1620 is. 
closed so that it disappears from the display device 106. Finally control is given 
back to the initial step 1501 for processing any future Scalable Template 
Instance Insertion Manager command. 

At step 1522, the local variable !STIM_height 1706 is incremented by 1 (one), as 
long as the sum of its value with the value of the local variable STIM_element 
remains less than or equal to the value of the local variable STIM_max. If the 
increment has been done, then the currently selected range of cells STIM^range 
1708 is enlarged by adding to the current selection a new row below the last one. 
Then control is given to step 1508. 

At step 1523, the local variable STIM_critical is updated in order to swap 
between the values \es" and W. Then the field "Critical" 755 within the record 
751 of the STIT table 750, as found at step 1503 is updated with the value of the 
local variable STIM^criticai Then control is given to step 1508. 
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• At step 1524, the local variable STIM_mode takes the value horeontaljnsert, or 
HORizoNTALjNSERT_BY_RANGE, if the Spreadsheet user has respectively clicked with 
the pointing device 105 on the option button 1606, or 1605. Then control is given 
to step 1508. 

5 • At step 1525, the STIT table 750 is visited to remove from it every record 751 
corresponding to a scalable template instance corrupted by the insertion of the 
new rows, as identified during the step 1509 for the insertion mode represented 
by the local variable STIM^mode, Each time such a record 751 has been 
removed from the STIT table 750, the "Reference Housekeeping Process", as 
10 described in step 1414 of the Scalable Template Instanciator method, is 
invoked and executed before looking for any other record 751 to . be removed 
from the STIT table 750. Then control is given to the step 1527. 

• At step 1526, the STIT table 750 is visited to remove from it every record 751 
con-esponding to a scalable template instance corrupted by the insertion of the 

15 new rows, as identified during the step 1514 for the insertion mode represented 
by the local variable STIM^mode. Each time such a record 751 has been 
removed from the STIT table 750, the "Reference Housekeeping Process", as 
described in step 1414 of the Scalable Template Instanciator method, is 
invoked and executed before looking for any other record 751 to be removed 

20 from the STIT table 750. Then control is given to the step 1528. 

• At step 1527 a test is perfonned to check the value of the local variable 
STIM_mode. If this value is found equal to horizontaljnsert then control is given 
to step 1529, if this value is found equal to horizontal_insert_by_range then 
control is given to step 1530- 

25 • At step 1528 a test is perfomied to check the value of the local variable 
STIM^mode. 

• If this value is found equal to horizontal^insert then control is given to step 
1531; 
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• if this value is found equal to horizontaljnsert_by„range then control is given 
to step 1533; 

• if this value is found equal to vefiticaljnsert then control is given to step 1 532; 

• if this value Is found equal to vertical_insert_by_range then control is given to 
5 step 1534. 

• At step 1529, the range of cells STIM_range I7O8 is selected to become the 
currently selected range of cells, with the currently selected cell being kept in its 
fomier position 1747 and then a regular operation of "row insertion" is perfonmed. 
Then control Is given to step 1535. 

10 • At step 1530, the range of cells STIM_range_coLfit 1721 is selected to becoine 
the currently selected range of cells, with the currently selected cell being moved 
to the position 1736 corresponding to the intersection of the leftmost column of 
the range of cells StlMJnstance_range 1713 with the row where was previously 
. located the currently selected cell 1707 and then a regular operation of "row 

IS insertion within selected range" is perfomned. Then control is given to step 1535. 

• At step 1531, the range of cells STIM^range 1748 Is selected to become the 
currently selected range of cells, with the currently selected cell being kept in its 
fomier position 1747 and then a regular operation of "row insertion" is perfonmed. 
Then control is given to step 1521 . 

20 • At step 1532, the range of cells STIM_range 1748 is selected to become the 
currently selected range of cells, with the currently selected cell being kept in its 
fomier position 1747 and then, a regular operation of "column insertion" is 
perfomied. Then control is given to step 1 521 . 

• At step 1533, the range of celte STIM_range 1748 is selected to become the 
25 currently selected range of cells, with the currently selected cell being kept in its 

former position 1747 and then a regular operation of "row insertion within 
selected range" is perfomied. Then control is given to step 1521. 
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• At step 1534, the range of cells STlMjrange 1748 is selected to become the 
currently selected range of cells, with the currently selected cell being kept in its 
former position 1747 and then a regular operation of "column Insertion within 
selected range" is perfonmed. Then control is given to step 1521. 

5 • At step 1535, a local variable STIMJndex is initialised to the value taken by the 
local variable STIM_height 1706. Then the STT table 720 is parsed to identify 
the record 721 whose ""Nam^ field 722 matches the value of the local variable 
ST_name, Within this record 721 is retrieved the Description Ptf field 724 
allowing to locate in memory the STDT table 760 associated to the scalable 

10 template that the current scalable template instance abides by. Then the element 
pair 762 of element format name and element profile name found within this 
STDT table 760 is set as the current pair of names: (fonmat name, profile name). 

• At step 1536, the EPT table 710 is parsed to find the record 711 whose "A/ame^' 
field 712 is found equal to the profile name within the current pair. Once this 

15 record 711 is found, its ""Description Ptf field 71 4 is retrieved to locate in memory 
the range of cells illustrating the profile. This description of the profile is 
copy-pasted by value only onto the currently selected cell, so that the 
corresponding row within the range of cells STI_range_coiJit 1721 or 1731 
, receives the profile initial values! Then the EFT table 700 is parsed to find the 

20 record 701 whose "A/ame^ field 702 is found equal to the fomnat name within the 
current pair. Once this record 701 is found, its ""Description Ptf field 704 is 
retrieved to locate in memory the range of cells illustrating the format. This 
description of the fomiat is copy-pasted by attribute only onto the currently 
selected cell, so that the corresponding row within the range of cells 

25 STLrange^colJit 1 721 or 1 731 receives the format attributes. 

• At step 1537, the local variable STIMJndex is decremented by 1 (one). Then 
control is given to step 1538. 
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• At Step 1538, a test is performed to check if the local variable STIMJndex is 
equal to 0 (zero). If it is the case, then control is given to step 1540, othenwise 
control is given to step 1539. 

• At step 1539, the cun-ently selected cell is moved downwards by one row. Then 
S control is given to step 1536. 

• At step 1540, the current scalable template instance STIMJnstance_range 1713 
is updated by restoring in all the elements the "OUT" cells to prevent any 
corruption due to the insertion. For this purpose the element profile name found 
at step 1535 within the pair 762 is used to identify the record 711 within the EPT 

10 table 710 whose "Nam^ field 712 matches this element profile name. Then the 
"Description Ptf field 714 of this same record 711 is used to retrieve in memory 
the profile illustrative range of cells which indicates the profile cells specified as 
"OUT" cells (recorded in a preferred embodiment of the present invention by 
setting the cell protection mode attribute to "cell protected frorn changes"). For 

15 this purpose, a temporary local variable STIM_ouUields memorises the relative 
positions of all the cells specified as "IN" or "OUT' cells, as an ordiared set.of in or 
OUT values. For instance in an element profile made of 5 cells,, where only the 
third and fifth cells are "OUr cells, this local variable STIM_out_fields takes the 
value (in, in, out, in, out). Then the top row of the inserted range of ceils 1721 or 

20 1731 is selected as the currently selected range of cells. Then each cell within 
this selection is individually deselected if it corresponds to d position taking the 
value "in" in the local variable STIM_outJields, Within this selection, the leftmost 
cell is set as the currently selected cell. At this stage, the current selection 
corresponds to the collection of all the "OUT" cells. Then the cunrent selection is 

25 extended by adding as many rows as needed above the current one, so that it 
spreads over all the elements located between the top one of the scalable 
template instance and the top one of the inserted new elements. Then a 
conventional "copy-up" operation is done to copy the "OUF cells of the last row 
of the current selection onto the above "OUT cells. Then the current selection is 

30 extended by adding as many rows as needed beldw the last one, so that it 
spreads over all the elements located within the scalable template instance. 
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Then a conventional "copy-down" operation is done to copy the "OUT" cells of 
the last row of the current selection onto the below "OUT cells, so that eventually 
all the "OUT* cells of the current scalable template instance receive a correct 
content. Finally the field "E/emenf jT 754 within the record 751 of the STIT table 
5 750, as found at step 1503 is updated with the sum of the local variables 
STIM^element and STIMJheight 1 706. Finally control is given to step 1 521 . 

• At step 1541, the local variable STIMJheight 1706 is decremented by 1 (one), as 
long as its value remains strictly positive. If the decrement has been done, then 
the currently selected range of cells STIM__range 1708 is reduced by removing 

10 from the current selection the last row. Then control is given to step 1508. 

E7. Scalable Template Instance Deletion Manager method 

The method for deleting within a scalable template instance either the content of 
selected cells, or selected elements or even the whole scalable template instance 
used in the preferred embodiment . of the present .invention is summarised in . 
15 flowchart 1800 of FIG 18. This method can be seen as the processing of the 
Scalable Template Instance Deletion Manager command. 

• At step 1801 , the method is in its default state, waiting for an event to initiate the 
process. 

• At step 1802, the Scalable Template Instance Deletion Manager command is 
20 ..dietected, as a result of a user action. This action can be for instance a specific 

combination of key on the keyboard 104, or the click of the pointing device 105 
on a specific button, or any other similar means not further specified here. 
When the Scalable Template Instance Deletion Manager command is 
detected, the current spreadsheet selection corresponds to a range of cells, 
25 possibly reduced to a single individual cell, which is known as the currently 
selected range of cells and which comprises the currently selected cell. If this 
currently selected cell is not the top left cell within the currently selected range of 
cells, then the top left cell of the cun-ently selected range of cells becomes the 
cunrently selected cell. 
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• At Step 1803, a test is performed to check if thie currently selected cell is located 
within an existing scalable template instance. This test is performed by parsing 
the STIT table 750 and visiting in each record 751 the "Addressl' Md 752 to 
detennine if the range of ceils address specified in this field does include the 

S address of the individual cun^ently selected ceil. If it is the case, then the cunrently 
selected cell ' is contained in a scalable template instance named 
STDMJhstance_mnge and control is given to step 1804 ; othenvise control is 
given to step 1811. 

• At step 1804, the record 751 found at the step 1803 is first retrieved to initialise 
10 local variables from its fields describing the scalable template instance 

STDMJnstance_range to which belongs the currently selected cell: the local 
variable ST_name is initialised with the value of the field "ST 753; the local 
variable STDM_element is initialised with the value of the "Element s field 754; 
the local variable STDM_critical \s initialised with the value of the "Critical' field 

15 755; the local variable STDM_lieader_size is initialisied with the value of the 
"Header Sizd" field 756; the local variable SWI\^_footer_siz0 is initialised with the 
value of the "Footer SizeF field 757. Then the locpl variable ST_name is used to 
parse the STT table 720 in order to find the record 721 whose "Namd' field 722 
matches the parameter ST_r)ame. Once this record 721 Is found, its field "M/n 

20 Element r 725 is memorized as the local variable STDM_min. Then another 
local variable STDM_mode is initialised with the value 
DeleteJN_fields_in_selected_ranqe. Then the position of the cunently selected 
cell is used to initialise the local variable STDM_offset_lieiglit corresponding to 
the number of rows between the top left cell of the range of cells 

25 STDMJnstance_range and the currently selected cell . Then the number of rows 
of the currently selected range of cells STDM_rar)ge is represented by the local 
variable SrDM_Aje/flf/7f. 

• At step 1805, a series of tests is performed to determine the relative position of 
the currently selected range of cells with respect to the cun-ent scalable template 

30 instance STDMJnstance_range. First a local variable STDM_header_overiap 
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takes the value 1 (one) if the value of the local variable STDM^offseLheight is 
less than the value of the local variable STDMJheaderjsizer, othenAdse the local 
variable STDM_header_overlap takes the value 0 (zero). Then a local variable 
STDM^footer_overlap takes the value 1 (one) if the sum of the values of the local 
5 variables STDM^offseLheight and STDMJheight is found greater than the sum 
of the values of the local variables STDM_header^$ize and STDM_element 
Then a local variable STDM_body_overlap takes the value of the fonmula: 
STDM_header_overlap x STDM_data1 + {^'STDM_header_overlap) x 
STDM_data2, where STDM_data1 takes the value 1 (respectively 0) if the sum of 

10 the values of the local variables STDM^offseLheight and STDM_height is found 
greater than (respectively less than or equal to) the value of the local variable 
STDM_header_size] and where STDM_data2 \akes the value 1 (respectively 0) if 
the value of the local variable STDM_offset_height is found , less than 
(respectively greater than or equal to) the sum of the values of the local variables 

15 STDM_header_si2e and STDM_element 

• At step 1806, the number of deleted elements is evaluated to then verify that the 
remaining number of elements will not be too small, that is below the lower limit 
STDM_min. This number of deleted elements is recorded in the local variable 
STDM_delete^element_#\Nhose value is given by the following fonmula: 

20 STDMJbody^overiap x ( STDMJheight - STDMJheader^overiap x 
{STDMJheader^size - STDM^offseLheighf) - STDMJooter^overiap x 
{STDM_offset_height'¥ STDMJheight - STDM^header^size- STDM_elemenfj). 

• At step 1807. a first local variable STDMJoo^smaii is set to the valuia "yes" if the 
sum of the values of the local variables STDMjdeieted_elementJf and 

25 STDM_min is found greater than the value of the local variable STDM^element, 
othenAflse this local variable STDMJoo^small takes the value "no". Then a 
second local variable STDM^outside_body is set to the value "no" if both the 
local variables STDM_header_overlap and STDMJooter__overlap take the value 
0 (zero); othenA^ise this local variable STDM_outside_body is set to the value 

30 'Ves". 
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At Step 1808, the Scalable Template Delete Manager Dialog Box 1900 Is 
displayed on the display device 106. The ""Criticar check box 1910 displays a 
check mat1< if the local variable STDMjcritical takes the value "Ves"; othenAnse 
(value "no"), the ""Criticar check box 1910 is kept with a blank empty display. The 
label box 191 1 Is Initialised with the value of the local variable STjname. The text 
box 1908 is filled with the value of the local variable STDMJheight The label box 
1907 is filled with the value of the local variable STDM_too_smail, and the label 
box 1904 is filled with the value of the local variable STDM_outsideJbody. Then 
if the local variable STDM_mode Xsikes the respective value 

•. DELETE_IN„FIELDSJN_SELECTED_RANGE, or 

• DELETE_IN_FIELDSJN_SELECTED_ROWS, Or 

• DELETE_SELECTED_ELEMENTS, or 

• DELETE_SELECTEDJNSTANCE, 

then the option button 1905, or 1906, or 1912, or 1913 displays alone a black 
point. Finally the ''Deleter push-button 1903 is disabled as soon as one of the 
following local variables takes the value "yes-: STDMJtooJiigh, 
STDM_outside^body, when the local variable STDM^mode Is equal to 
delete_selected_elements; othenwise the ''Delete push-button 1903 is enabled: 

At step 1809, the method is waiting for any user action on the Scalable Template 
Delete Manager Dialog Box 1900. Such user action is typically resulting from a 
click with the pointing device 105, but take other similar forms such as, but not 
limited to a specific combination of key on the keyboard 104, or any other similar 
means not further specified here. 

At step 1810, a user action on the Scalable Template Delete Manager Dialog 
Box 1900 is detected. 

• If the user action is a click on the "De/efe^ push-button 1903, then control is 
given to step 1824; 

• if the user action is a click on the upper part of the spin button 1909, then 
control is given to step 1 821 ; 
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• if the user action is a click on the lower part of the spin button 1909, then 
control is given to step 1820; 

• if the user action is a click on the "Criticar check box 1910, then control is 
given to step 1822; 

5 • if the user action is a click on one of the option buttons 1906, or 1905, or 1912, 
or 1913, then control is given to step 1823; 

• if the user action is a click on the "Cancef push-button 1902, or on the 
closing-window push-button 1901, then control is given to step 1830. 

• At step 1811, the local variable STDM_mode is initialised with the value 
10 coNTENT_DELETE. Then the number of rows and of columns of the currently 

selected range of cells STDM^range 2002 is represented respectively by the 
local variables STDM^height and STDM^width. Then the range of cells 
STDM^righLrange 2003 is determined as the range of cells sharing the same 
rows as STDM^range 2002, and occupying the columns located on the right of 

15 the range of cells STDM_range 2002. Then the range of cells 
STDM_bottom_range 2004 is determined as the range of cells sharing the same 
columns as STDM^range 2002, and occupying the rows located below those of 
STDM^range 2002. Then the range of cells STDMJeft_range 2005 Is 
detemriined as the range of cells sharing the same rows as STDM_range 2002, 

20 and occupying the columns located on the left of the range of cells STDM^range 
2002. Then the range of cells STDM_top_range 2006 is detemiined as the range 
of cells sharing the same columns as STDM_range 2002, and occupying the 
rows located above those of STDM^range 2002. 

• At step 1812, several tests are performed to evaluate the potential impact of the 
25 deletion, according to four possible deletion modes, on any already existing 

scalable template instance or data. These tests require to parse the STIT table 
750, and to visit each record 751 to leam the address {"Addres^' field 752) and 
the importance {"Criticar field 755) of every already defined scalable template 
instance. These tests evaluate either if two given ranges of cells partially overiap 
30 (meaning that there exist in the first range of cells at least one cell belonging to 
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the second range of cells and at least one cell not belonging to the second range 
of cells) or if a first given range of ceils is included within a second given range of 
cells (meaning that every cell belonging to the first range of cells also belongs to 
the second range of cells). Different conventional range comparison. techniques 
5 can be used for evaluating either range partial overlapping or range inclusion, 
without departing from the spirit of the present invention; they will not be 
described In the preferred embodiment of the present Invention. 

First the horeontal_delete mode of deletipn is Investigated. 
10 • If there exists at least one existing scalable template instance whose ^'CriticaF 
field 755 takes the value "yes" and which partially overlaps the range of cells 
made of the entire rows where is located the currently selected range of cells 
... STDM_range 2002, or which is included in the range of cells made of the 
entire rows where is located the cun-ently selected range of cells STDM_range 
15 2002, then the local test variable STDM_horizontaLcritical takes the value 
'Ves"; othenA^ise the local test variable STDM^horizontaLchtical takes the 
value "no". 

• If there exists at least one existing scalable template instance whose "Criticar 
field 755 takes the value "no" and which partially overiaps the range of cells. 

20 made of the entire rows where is located the currently selected range of cells 
STDM_range 2002, or which is Included in the range of cells made of the 
; entire rows where is located the currently selected range of cells STDM_range 
2002, then the local test variable STDM^horizontaLothertakes the value, "yes"; 
. othenA/ise the local test variable STDM_hprizontaLother takes the value "no". 

25 • If all the cells within the range of cells made of the entire rows where is located 
the currently selected range of cells STDM_range 2002 are.empty (containing 
none data), then the local test variable STDM_horizontal_data takes the value 
"no"; othenA/lse the local test variable STDM_horizontal_data takes the value 
"yes". 

30 

Second the horizontal_delete_by_range mode of deletion is investigated. 

• |f there exists at least one existing scalable template instance whose "Criticar 
field 755 takes the value "yes" and which partially overiaps the range of cells 
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constituted by the concatenation of the two ranges of cells STDM^range 2002 
and STDM_bottom_range 2004, or which partially overlaps or is included in 
the range of cells STDM^range 2002, then the local test variable 
STDM_horizontaLrange_critical takes the value "yes"; othenvise the local test 
5 variable STDM_horizontal_range_critical takes the value "no". 

• If there exists at least one existing scalable template instance whose "Cnf/car 
field 755 takes the value "no" and which partially overlaps the range of cells 
constituted by the concatenation of the two ranges of cells STDM_range 2002 
and STDM_bottom_range 2004, or which partially overlaps or is included in 

• 10 the range of cells STDM_range 2002, then the local test variable 
STDM_horizontaLrange_other takes the value "yes"; othenA^ise the local test 
variable STDM_horizontaLrange_other takes the valuie "no". 

• If all the cells within the range of cells STDM^range 2002 are empty 
(containing none data), then the local test variable 

15 STDM_horizontaLrange_data takes the valud "no";. othenArise the local test 
variable STDM_horizontaLrange_data takes the value "yes". 

Third the vertical_delete mode of deletion is investigated. 

• If there exists at least one existing scalable template instance whose "Criticar 
20 field 755 takes the value "yes" and which partially overiaps the range of cells 

made of the. entire columns where is located the currently selected range of 
cells STDM_range 2002, or which is included in the range of cells made of the 
entire columns where is located the currently selected range of cells 
STDM^range 2002, then the local test variable STDM^verticaLcritical takes 
25 the value "yes"; othenwise the local test variable STDM^verticaLcritical takes 
the value "no". 

• If there exists at least one existing scalable template instance whose "Criticar 
field 755 takes the value "no" and which partially overiaps the range of cells 
made of the entire columns where is located the currently selected range of 

30 cells STDM^range 2002, or which is included in the range of cells made of the 
entire columns where is located the cun-ently selected range of cells 
S7D/W.ransfe2002, then the local test variable STDM__verticaLother takes the 
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value "yes"; otherwise the local test variable STDM_verticaLother takes the 
value "no". 

• If all the cells within the range of cells made of the entire columns where is 
located the cunrently selected range of cells STDM^range 2002 are empty 

S (containing no data), then the local test variable STDM^verticaLdata takes the 
value "no"; othenwise the local test variable STDM^verticaLdata Xakes the 
value "YEs"i 

Fourth the verticaCdelete_by_range mode of deletion is investigated. . 

.10 • If there exists at least one existing scalable template instance whose ""Criticar 
field 755 takes the value "yes" and which partially overiaps the range of cells 
constituted by the concatenation of the. two ranges of cells STDM^range 2002 
and STDM^righLrange 2003, or which partially overiaps or is included in the 
range of cells STDM^range 2002, then the local test, variable 

15 STDM_vertical_range_critical takes the value "yes"; othenfl^ise the local test 
variable STPM_verticaLrange_critical takes the value "no". 

• If there exists at least one existing scalable template instance whose "CriticaP 
field 755 takes the value "no" and which partially overiaps the range of cells 
constituted by the concatenation of the two ranges of cells STDMyange 2002 

20 and STDM^HghLrange 2003, or which partially overiaps or Is included in the 
range of cells STDM^range 2002, then the local tesX variable 
STDM^verticaLrange^other takes the value "yes"; othenwise the local test 
variable STDM^verticaLrange^othertakes the value "no". 

• If all the cells within the range of cells STDM^range 2002 are empty 
25 (containing no data), then the local test variable STDM_verticaLrange_data 

takes the value "no"; otherwisie the local test variable 
STDM_verticaLrange_data takes the value \es". 

Fifth the contenOelete mode of deletion is investigated. 

• If there exists at least one existing scalable template instance whose "Criticar 
30 field 755 takes the value "yes" and whose intersection with the range of cells 

STDM_range 2002 contains at least one element or meta-element cell 
specified as "OUT* cell, then the local test variable STDM^contenCcritical 
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takes the value \es"; otherwise the local test variable STDMjcontentjcritical 
takes the value "no". 

• If there exists at least one existing scalable template instance whose ""CiiticaP 
field 755 takes the value "no" and whose intersection with the range of cells 
STDM_range 2002 contains at least one element or meta-element cell 
specified as "OUT cell, then the local test variable SrDM_confenLof/7er takes 
the value "yes"; othenwise the local test variable STDM^contenLother takes 
the vialue "no". 

• If all the cells within the range of cells STDM^range 2002 are empty 
(containing no data), then the local test variable STDM_content_data takes the 
value "no"; othenA/ise the local test variable STDM^contenLdata takes the 
value *Ves". 

At step 1813, a test is performed to check the deletion impact on any existing 
scalable template instance, according to the values assigned during the step 
1812 to the local variables 

• STDM_horizontal_critical, 

• STDM^horizontaLother, 

• STDM_horizontaLrange_cntical, 

• STDM_horizontaLrange_othen 

• STDM^verticaLcritical, 

• STDM^verticaLother, 

• STDM_verlicaLrange_critical, 

• STDM_verticaLrange_other, 

• SfDM_content_critical, 

• STDM_content_other. 

If none of these local variables takes the value "yes", then control is given to step 
1814; othenA^ise if at least one of these local variables takes the value "yes", then 
control is given to step 1815. 

At step 1814, the conventional deletion method as used and defined in 
conventional electronic spreadsheet environments is triggered, and then control 
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is given back to the initial step 1801 for processing any future Scalable 
Template Instance Deletion Manager command. 

• At step 1815y the Scalable Template Delete Manager Dialog Box 1920 is 
displayed on the display device 106. The label box 1929 is initialised with the 
S reserved value "None". The 15 label boxes 1924 are filled row after row, starting 
with the top row, from the left to the right, with the values of the following local 
variables in the following order: 

• STDMjcontentjoritical, 

• STDM^contenLother, 
10 • STDM_content_data, 

• STDM_horizontaLcritical, 

• STDM_horizontal_other, 

• STDM_horizontal_data, 

• STDM_horizontaLrange_critical, 
15 • STDM_horizqntaLrange_other, 

• STDM_horizontaLrange_data, 

• STDM_verticaLcritical, 

• STDM_vertical_other, 

• STDM^verticaLdata, 

20 • STDM_vertical_range_critical, 

• STDM_verticaLrange_other, 

• STDM^veriicaLrange^data. 

Then if the local variable STDM^mode takes the Yespective value 

GONTENT_DELETE, Or HORIZONTAL_DELETE, Or HORIZONTAL_DELETE_BY_RANGE, Or 

25 VERTicAL_DELETE, or vERTicAL_DELETE_BY_RANGE, then the option button 1930, or 
1928, or 1927. or 1926, or 1925 displays alone a black point. 

Finally the "Delete!* push-button 1923 is disabled as soon as one of the following 
local variables takes the value "yes": 

• STDM_contenLcritical (only taken into account if the local variable 
30 STDM_mode is equal to content_delete), 
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• STDM^horizontaLcritical (only taken into account if the local variable 
STDM^mode is equal to horizontaljelete), 

• STDM^verticaLcritical (only taken into account if the local variable 
STDM_mode is equal to vertical^delete), 

• STDMJhorizontaLrangejoritical (only taken Into account if the local variable 
. STDM^mode is equal to hor!zontal_delete_by_range), 

• STDM_verticaLrangejcritical (only taken into account if the local variable 
STDM^mode is equal to vertical_delete„by_range); 

othenwise the "De/efe^' push-button 1923 is enabled! 

At step 1816, the method is waiting for any user action on the Scalable Tennplate 
Insert Manager Dialog Box 1920. Such user action is typically resulting from a 
click with the pointing device 105, but take other similar forms such as, but not 
limited to a specific combination of key on the keyboard 104, or any other similar 
means not further specified here. 

At step 1817, a user action on the Scalable Template Insert Manager Dialog Box 
.1920 is detected. If the user action is a click on the "Detefe^ push-button 1923, 
then control is given to step 1819; if the user action Is a click on one of the option 
buttons 1930, or 1928, or 1927, or 1926, or 1925, then control is given to step 
1818; if the user action is a click on the "Cancer push-button 1922, or on the 
closing-window push-button 1921, then control is given to step 1830. 

At step 1818, the local variable STDMjDode takes the value content_delete, or 
HORizoNTAL_DELETE, or horizontal_delete_by_range, or vertigal^delete, or 
vertical_delete_by_range if the spreadsheet user has respectively clicked with 
the pointing device 105 on the option button 1930, or 1928, or 1927, or 1926, or 
1925. Then control is given to step 1815. 

At step 1819, the STIT table 750 is visited to remove from it every record 751 
corresponding to a scalable template instance corrupted by the deletion 
operation, as identified during the step 1812 for the deletion mode represented 
by the local variable STDM^mode. Each time such a record 751 has been 
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removed from the STIT table 750, the "Reference Housekeeping Process", as 
described in step 1414 of the Scalable Template Instanciator method, is 
invoked and executed before looking for any other record 751 to be removed 
from the STIT table 750. Then control is given to the step 1825. 

5 • At step 1820, the local variable STDMJheight 'xs decremented by 1 (one), as long 
as its value remains strictly, positive. If the decrement has been done, then the 
currently selected range of ceils STDM^range Is reduced by removing from the 
current selection the last row. Then control is given to st^p 1805. 

• At step 1821, the local variable STDM^height is incremented by 1 (one), as long 
10 as its value remains less than the value of the local variable STDM^element If 

the increment has been done, then the currently selected range of cells 
STDM^range is enlarged by adding to the current selection a new row below the 
last one. Then control is given to step 1805. 

• At step 1822, the local variable STDM_critical is updated in order to swap 
15 between the values "yes" and "no". In addition, a check mari< is respectively 

added within or removed from the ""Critlcar check box 1910 if it was previously 
absent or present in this same check box 1910. Then the field ''Critlcar 755 
within the record 751 of the STIT table 750, as found at step 1803 is updated 
with the value of the local variable STDM^critlcaL Then control is given to. step 
20 1805. 

• At step 1823, the local variable STDM^mode takes the value 

"DeleteJN_fieldsjn„selected_range", or "delete_IN_fieldsjn_selected_rows", 
or "delete_selected_elements", or "delete_selected_instance", if the spreadsheet 
user has respectively clicked with the pointing device 105 on the option button 
25 1905, or 1906, or 1912, or 1913. Then control is given to step 1805. 

• At step 1824 a test is perfomned to check the value of the local variable 
STDM^mode, 
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• If this value is found equal to "delete_IN_fieldsjn_selected_range" then 
control is given to step 1826; 

• if this value is found equal to "deleteJN_fields_in_selected_rows" then control 
is given to step 1827; 

5 • if this value Is found equal to "delete:.selected_elements" then control is given 
to step 1828; . 

• if this value is found equal to "delete_selectedjnstance" then control is given 
to step 1829. 

• At step 1825 a test is performed to check the value of the local variable 
10 STDM^mode. 

• If this value is found equal to horizontal_delete then control is given to step 
1831; 

• if this value is found equal to horizontal_delete_by_range then control is given 
to step 1833; 

15 •if this value is found equal to vertical_delete then control is given to step 1832; 

• if this value is found equal to vertical_delete_by_range then control is given to 
step 1834; 

• If this value is found equal to cgntent_delete then control is given to step 
1837. 

20 • At step 1826, the "IN" cells belonging to the currently selected range of ceils 
STDM^range are cleared. For this purpose, the "SF field 753 of the record 751 
of the STIT table 750, as identified at step 1803, is visited to get a memory 
pointer on the STDT table 760 of the scalable template, which specifies for each 
meta-element and for each element of the scalable template instance what is the 

25 associated profile, which in turn indicates which cells are "IN" cells and which 
cells are "OUT" cells. Then each row of the range of cells STDM^range is 
selected one after the other, and for each selected row, the corresponding 
element or meta-element profile is retrieved from the STDT table 760 to 
determine which cells are "IN" cells. For this purpose, a temporary local variable 

30 STDM_out_fields memorises the relative positions of all the cells specified as 
"IN" or "OUT' cells, as an ordered set of in or out values. For instance in an 
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element profile made of 5 cells, where only the third and fifth cells are "OUT 
cells, this local variable STDM_out_fields takes the value (in, in, out, in, out). 
With the same example, if the selected range of cells was only occupying the 
second, third and fourth columns of the scalable template instance, then the first 
S cell is ignored because although it is an "IN" cell, it falls outside the limits of the 
range of cells STDM^range, so that only the second and fourth cells are taken 
into account. Once the "IN" cells belonging to the range of cells STDM^range are 
detemiined, these cells are updated by clearing their content. 

• At step 1827. the currently selected range of cells STDM_range is updated in 
10 order to align its columns with those occupied by the scalable template instance 

STDMJnstance_range. Then control is given to step 1826. 

• At step 1828, the elements belonging to the rows of the currently selected range 
of cells STDM_range are removed from the current instance 
STDMJnstance_range. For this purpose is first selected the range of cells 

15 constituted by the same columns as the range of cells STDMJnstance_range, 
and whose rows are located between the bottom row of the range of cells 
STDM_range (excluded) and the bottom row of the range of cells 
STDMJnstance_range (included). Then this selected range of cells is moved 
upwards, row after row, up to the position where its top row occupies the same 

20 row as the top row of the. former range of cells STDM^range. For each step of 
this move, a row within the range of cells STDM_range is removed, so that at the 
end all the rows of the range of cells STDM_range are removed. Then control is 
given to step 1836. 

• . At step 1829, the range of cells corresponding to the scalable template instance 
25 STDMJnstance_range becomes a regular ranges of cells and looses its quality 

of scalable template instance. For this purpose, the content of all the cells of this 
range of cells STDMJnstance^range is cleared, and then this whole range of 
cells receives the default display attributes defined within the current 
spreadsheet file. Then control is given to step 1835. 
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At Step 1830, the Scalable Template Delete Manager Dialog Box 1900 or 1920 is 
closed so that it disappears from the display device 106. Finally control is given 
back to the initial step 1801 for processing any future Scalable Template 
Instance Deletion Manager command. 

At step 1831 , the range of cells STDM_i^nge is selected to become the cunently 
selected range of cells so that STDM_height rows are selected, and then a 
regular operation of "row deletion" is perfomied. Then control is given to step 
1830. 

At step 1832, the range of cells STDM_range is selected to become the currently 
selected range of cells so that STDM_width columns are selected, and then a 
regular operation of "column deletion" is perfomied. Then control is given to step 
1830. 

At step 1833, the range of cells STpM_range is selected to become, the cun^ntly 
selected range of cells so that STDM_helght::rows are selected, and then a 
regular operation of "row deletion within selected range" is perfonned. Then 
control is given to step 1830. 

At step 1834, the range of cells STDM_range is selected to become the currently 
selected range of cells so that STDM_width columns are selected, and then a 
regular operation of "column deletion within selected range" is perfonned. Then 
control is given to step 1830. 

At step 1835, the record 751 identified at step 1803 is removed from the STIT 
table 750. Then the "Reference Housekeeping Process", as described In step 
1414 of the Scalable Template Instanciatop method, is executed, before giving 
control to the step 1830. 

At step 1836, the current scalable template instance STDMJnstance_range is 
updated by restoring in all the remaining elements the "OUT" cells to prevent any 
conuption due to the element deletion. First the STT table 720 is parsed to 
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identify tlie record 721 whose "Nam^ field 722 matches the value of the local 
variable ST_name. Within this record 721 is retrieved the "Description Ptf field 
724 allowing to locate in memory the STDT table 760 associated to the scalable 
template that the cunrent scalable template instance STDMJnstance^range 
5 abides by. Then the element pair 762 within this STDT table 760 is accessed to 
retrieve the element profile, recorded in the local variable STDMjprofile. Then 
the EPT table 710 is parsed to identify a record 711 whose "A/aniW' field 712 
matches the iocal variable STDMjprofile. Once found, the "Description Ptf field 
714 is used to access in memory a description of the element profile which 

10 indicates which cells are "IN" cells arid which cells are "OUT" cells. For this 
. purpose, a temporary local variable STDM_out_fields memorises the relative 
positions of all the cells specified as "OUT" cells, as an ordered, set of in or out 
values. For instance with an element profile made of 5 cells, where only the third 
and fifth cells are "OUT' cells, this local variable STDM_out_fi.elds takes the 

15 value (in, in, out, in, out). Then each "OUT" cell of the illustrative range of cells 
(pointed by the "Description Ptf field 714 of the riecord 711 of the EPT table 710 
whose "Name" 712 field matches the local variable. SrDW_prof//e) is indi>>l,dually 
copied and pasted onto the cell of the top element of the scalable template 
instance STDMJnstance_range which has the same relative column offset within 

20 the element (conresponding to a position taking the value "our" in the local 
variable STbM_outJields). Then the top element of the scalable template 
Instance STDMJnstance_range is selected as the cun-elntly selected; range of 
ceils. Then each cell within this selection is individually deselected if it 
con-esponds to a position taking the value "in" in the local variable 

25 STDM_out_fields. Within this selection, the leftmost cell is set as the currently 
selected cell. At this stage, the cun^nt selection corresponds to the collection of 
all the "OUT" cells. Then the current selection is extended to include as many 
rows as needed below the top element, so that it spreads over all the elements of 
the scalable template instance STDMJnstance_range. Then a conventional 

30 "copy-down" operation is done to copy the first row onto the below ones, so that 
all the "OUF cells of the current scalable template instance 
STDMJnstance_range receive a correct content. Finally the "Element #" field 
754 within the record 751 of the STIT table 750, as found at step 1803 is 
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updated with the difference of the local variables STDM_^element and 
STDMJieight Finally control is to step 1830. 

• At step 1837, the content of every cell comprised within the currently selected 
range of cells STDM_range is cleared. Then control is given to step 1830. 

5 E8. Scalable Template Refresh Manager method 

The method for updating the definition of existing scalable template objects (either 
element formats, or element profiles, or meta-element formats or meta-element 
profiles) so that each defined scalable template instance abiding by these objects 
get automatically refreshed, used in the preferred embodiment of the present 
10 invention is summarised in flowchart 2100 of FIG 21. This method can be seen as 
the processing of the Scalable Template Refresh Manager command. 

• At step 2101 , the method is in its default state, waiting for an event to initiate the 
process. 

• At step 2102, the Scalable Template Refresh Manager command is detected, 
15 as a result of a user action. This action can be for instance a specific 

combination of key on the keyboard 104. or the click of the pointing device 105 
on a specific button, or any other similar means not further specified here. 

• At step 2103, the command parameters are retrieved and memorized in local 
variables. The first command parameter is recorded in the local variable 

20 STRMjname. The second command parameter is recorded in the local variable 
STRMjype. The third optional command parameter is recorded, when present, 
in the local variable STRM__old If the value of the local variable STRM^type is 
found equal to format, then the EFT table 700 is scanned to find the record 701 
. whose "A/ame " field 702 is equal to the local variable STRM^name, When this 

25 record 701 is found, the local variable STRM^ref is initialised \N\Xh the value of 
the referenced attribute 709 of the 'Typef' field 707; then the STRM_new local 
variable is initialised with the content of the memory location pointed by the 
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''Description Ptf field 704; and then the STRM^width local variable is Initialised 
with the value of the "Column field 706. If the value of the local variable 
STRMJtype is found equal to profile, then the EPT table 710 Is scanned to find 
the record 711 whose "A/a/ne " field 712 is equal to the local variable 
5 STRM_name. When this record 711 is found, the local variable STRM^ref is 
initialised with the value of the referenced attribute 719 of the "Typef' field 717; 
then the STRM^new local variable is initialised with the content of the memory 
location pointed by the Description Ptf field 714; and then the STRM_width 
local variable is initialised with the value of the Column field 71 6. . 

10 • At step 2104, a test is perfonned to check if the value of the local variable 
STRM_ref\s equal to instance. If it is the case, then control is given to step 2106; 
otherwise control is given to step 2105. 

• At step 2105, a warning message notification is issued for infomiing the user that 
there is no instance defined which uses the format or profile definition, so that 

15 the Refresh operation is not needed. This can typically be done by displaying on 
the display device 106 a warning message in a pop-up window, or in a status bar 
area, but any other similar means could be used instead, without departing from 
the spirit of the invention. Once the user has acknowledged this notification 
. message through conventional means such as clicking with the pointing device 

20 1 05 on ah "OK*' push-button present within a warning message pop-up window, 
or any other similar means without departing from the spirit of the invention, 
control is given back to the initial step 2101 for processing any future Scalable 
Template Refresh Manager command. 

• At step 2106, if the value of the local variable STRMJtype is found equal to 
25 FORMAT, then a local variable STRMJNjtoJN is initialised as a range of cells 

made by a single row and by a number of columns equal to the value of the local 
variable STRM^widtlf). The n-th cell within this range of cells STRMJNJoJN 
takes the value \es" if both the n-th cell of the range of cells S77=?/W_o/d and the 
n-th cell of the range of cells STRMjiew have been specified as "IN" cells; 
30 othenvise the n-th cell within this range of cells STRMJNjtoJN takes the value 



227 



wo 03/014987 



PCT/EP02/09483 



"no". This local variable will be later used to determine the cells which have 
remained as "IN" ceils. 

Then regardless of the value of the local variable STRMjtype, a conventional 
copy operation (both, by attribute and by content) is performed from the range of 
cells STRM_new onto the clipboard. Finally the first record 721 of the STT table 
720 is set as the cun-ent record in the local variable STRM_STT_rec. 

At step 2107, the STDT table 760 pointed by the "Description Ptf field 724 of the 
current record 721 STRM_STr_rec is set as cun-ient STDT table 760 recorded in 
the local variable STRM_STDT. Then the first pair of names 761 (format name, 
profile name) within the STDT table 760 STRM_STDT is set as the current pair 
recorded in the local variable STRM_pair. Then the local variable STRM_offset \s 
initialised to the value 0 (zero), then the local variable ST_name is set to the 
value of the "Nam^ field 722 of the record 721 STRM_STT_rec and then the 
local variable STRMJop is set to the value of the "Header Siz^ field 756 of the 
record 721 STRM_STT_rec. 

At step 2108, a test is performed to check if the name recorded in the. local 
variable STRM_name is found in the pair of names STRM jpair. If it is the case, 
then control is given to step 21 1 4; otherwise control is given to step 2109. 

At step 2109, a test is perfomied to check if the current pair of names 
STRMjpair 'xs the last pair 763 of the current STDT 760 table STRM_STbT. If it 
Is the case, theri control is given to step 2110; othenwise control is given to step 
2111. 

At step 2110, a test is perfomied to check if the cun-ent recorri 721 
STRM_STT_rec is the last record of the STT table 720. If it is the case, then 
control is given to step 2112; othenwise control is given to step 2113. 

At step 2111, the pair following the cun-ent pair STRM_pair in the cunent STDT 
table Sr/?M_SrDr becomes the new cun-ent pair STRMjjair, and then the local 
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variable STRM_offset is incremented by 1 (one). TTien control is given to step 
2108. 

At step 2112, an infonnation message notification is issued for infonning the user 
that the Refresh operation is complete. This can typically be done by displaying 
on the display device 106 an infomiation message in a pop-up window, or in a 
status bar area, but any other similar means could be used , instead, without 
departing from the spirit of the invention. Once the user has acknowledged this 
notification message through conventional means such as clicking with the 
pointing device 105 on an "OK" push-button present within an information 
message pop-up window, or any other similar means without departing from the 
spirit of the invention, control is given back to the Initial step 2101 for processing 
any future Scalable Template Refresh Manager command. 

At step 2113, the record following the cun-ent record 721 STRM_STT_rec in the 
STT table 720 becomes the new current record 721 STRM_STT_rec. 

At step 2114, the first record 751 of the STIT table 750 |s set as the cun-ent 
record in the local variable STRM_STIT_rec. 

At step 2115, a test is perfomied to check if the value of the "ST field 753 within 
the current record 751 STRM_STIT_rec\s equal to the value of the local variable 
ST_name. If it is the case, then control is given to step 2118; othenvise control is 
given to step 2116. 

At. step 2116, a test is performed to check if the current record 751 
STRM_STIT_rec is the last record of the STIT table 750. If It is the pase, then 
control is given to step 2109; othenwise control is given to step 2117. 

At step 2117, the record following the current record 751 STRM_STIT_rec in the 
STIT table 750 becomes the new cun-ent record 751 STRM_STIT_rec. Then 
control is given to step 21 1 5. 
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At Step 2118, the top left cell of the range of cells whose address is specified by 
the "Address field 752 of the current record 751 STRM_STIT_mc, is selected. 
Then the selection is moved down by a number of rows equal to the value of the 
local variable STRM_offset Then the local variable STRM_body is set equal to 
the value of the "Element field 754 of the cun-ent record 751 STRM_STIT_rec. 

At step 2119, a test is perfomied to check if the value of the local variable 
STRM_top is found less than the value of the local variable STRM_offset. If It is 
the case, then control is given to step 2120; othenwise control is given to step 
2121. 

At step 2120, the currently selected cell is moved down by a number of rows 
equal to the value of the local variable STRMJbody decremented by 1 (one). 

At step 2121, a test is perfomied to check if the value of the local variable 
STRMJype is equal to format. If it is the case, then control is given to step 21122; 
othenwise contrql is given to step 21 25. 

At step 2122, a test is perfomied to check if the value of. the local variable 
STRM_top is found equal to the value of the local variable Sr/?/W_ofeef. If it is 
the case, then control is given to step 2123; othenwise control is given to step 
2124. 

At step 2123, the current selection is extended by selecting down a number of 
rows equal to the value of the local variable STRM_body decremented by 1 
(one). 

At step 2124, a conventional paste operation by attribute Is perfomied from the 
content of the clipboard onto the current selection. 

At step 2125, a test is perfomied to check if the value of the local variable 
STRM_top is found equal to the value of the local variable STRM_offset. If it is 
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the case, then control is given to step 2127; othenArise control is given to step 
2126. 

At step 2126, the local variable STRMJndex is set to the value 1 (one). Then 
control is given to step 2128. 

At step 2127, the local variable STRMJndex is set to the value of the local 
variable STfl/WLfcocfy. 

At step 2128, the local variable STRM^right is set to the value 0 (zero). 

At step 2129, a test is performed to check if two conditions are fulfilled.. 

T The first condition consists in finding in the local variable STRMJN_toJN the 
cell of rank STRM^right equal to the value 'Ves" (where the rank is set to zero 
for the left most cell, and incremented by one for each neighbour cell on the 
right). 

• The second condition consists in finding the content of the currently selected 

cell different from the cell of rank STRM^rightm the local variable STRM^old. 
If both conditions are fulfilled, then control is given to step 2131; othenvise 
control is given to step 2130. 

At step 2130, a conventional copy-paste operation by content only is perfonjied 
from the cell of rank STRM_right within the local variable STRM^new onto the 
currently selected cell. 

At step 2131, a test is performed to check if the value of the local variable 
STRM_right is found equal to the value of the local variable STRM^width 
decremented by 1 (one). If it is the case, then control is given to step 2133; 
othenA/ise control is given to step 2132. 

At step 2132, the local variable STRM_^right is incremented by 1 (one), and then 
the currently selected cell is moved right by one column. Then control is given to 
step 2129. 
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• At Step 2133, the local variable STRMJndex is decremented by 1 (one). 

• At step 2134, a test Is performed to check if the value of the local variable 
STRMJndex is found equal to 0 (zero). If it is the case, then control is given to 
step 2109; otherwise control is given to step 2135, 

5 • . At step 2135, the currently selected cell is moved down by one row, and left by a 
number of columns equal to the value of the local variable STRM__width 
decremented by 1 (one). Then control is given to step 2128. 

E9. Scalable Template Instance Copy Manager method 

The method for performing a copy operation on a source scalable template instance 
10 used in the preferred embodiment of the present inventipn is summarised in 
flowchart 2400 of FIG 24A. This method can be seen as the processing of. the 
Scalable Template Instance Copy Manager command. 

• At step 2401 , the method is in its default state, waiting for an event to initiate the 
process. 

15 • At step 2402, the Scalable Template Instance Copy Manager command is 
detected, as a result of a user action. This action can be for instance a specific 
combination of key on the keyboard 104, or the click of the pointing device 105 
on a specific button, or any other similar means not further specified here. 
When the Scalable Template Instance Copy Manager command \s detected, 

20 the current spreadsheet selection, corresponds to a range of cells, possibly 
reduced to a single individual cell, which is known as the cun-ently selected range 
of cells and which comprises the currently selected cell. If this currently selected 
cell is not the top left cell within the currently selected range of cells, then the top 
left cell of the currently selected range of cells becomes the cun-ently selected 

25 cell. 
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At Step 2403,. a test is performed to check if the currently selected cell is located 
within any existing scalable template instance. This test is perfomied by parsing 
the STIT table 750 and visiting in each record 751 the ''Address field 752 to 
detemiine if the range of cells address specified in this field does include the 
address of the individual currently selected cell. If it is the case, then the currently 
selected cell is contained in a scalable template instance named 
STCopyMJnstance^mnge and control is given to step 2404 ; othenwise control 
is given to step 2414. 

At step 2404, some local variables are initialised. The local variable 
STCopyM_mdde takes the default value "range". The local variable 
SrCopyA^Lo/feef takes the value equal to the number of rows between the top 
row of the scalable template instance STCopyMJnstance^range and the row of 
the currently selected cell (for instance if the currently selected cell is located on 
the same row as the top row of the scalable template instance 
STCopyMJnstance__range, then the local variable STCopyM^offset takes the 
value 0). The local variable STCopyM^name takes the value of the name of the 
scalable template thiat the scalable template instance STCopyMJnsiance_rarige 
abides by. This name can be retrieved from the "Sr field 753 within the record 
751 of the STIT table 750, associated to the scalable template instance 
STCopyMJnstance_range. The local variable STCopyM_element takes the 
value equal to the number of rows belonging both to the currently selected range 
of cells and to the scalable template instance STCopyMJnstance^range. Finally 
the local viariable STCopy/WLboofy takes the value equal to the current number of 
elements within the scajable template instance STCopyMJnstance^range. This 
number can be retriiBviBd from the "Element IF field 754 within the record 751 of 
the STIT table 750, associated to the scalable template instance 
STCopyMJn$tance_range. 

At step 2405, the Scalable Template Instance Copy Manager Dialog Box 2300 is 
displayed on the display device 106. The label box 2311 is initialised with the 
value of the local variable STCopyM__name. Then if the local variable 
STCopyM^mode takes the respective value range, or element, or instance, then 
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the option button 231 0» or 2309, or 2308 displays alone a black point. Finally the 
three text boxes 2305, 2306 and 2307 are initialised with the value "yes" 
regardless of any local variable value (these text boxes are present on the 
Scalable Template Instance Copy Manager Dialog Box 2300 for consistency with 
5 the Scalable Template Instance Cut Manager Dialog Box 2320 and the Scalable 
Template Instance Paste Manager Dialog Box 2340). 

• At step 2406, the method is waiting for any user action on the Scalable Template 
Instance Copy Manager Dialog Box 2300. Such user action is typically resulting 
from a click with the pointing device 105, but take other similar forms such as, 

10 but not limited to a specific combination of key on the keyboard 104, or any other 
similar means not further specified here. 

• At step 2407, a user action on the Scalable Template Instance Copy Manager 
Dialog Box 2300 is detected. 

• If the user action is a click on the "Cop/ push-button 2303, then control is 
15 given to step 2409; 

• if the user action is a click on one of the option buttons 2310, or 2309, or 2308, 
then control is given to step 2408; 

• If the user action is a click on the "Cancer push-button 2302, or on the 
closing-window push-button 2301 , then control is given to step 241 6. 

20 • At step 2408, the local variable STCopyM_mode takes the value "range", or. 
"ELEMENf', or "instance", if the spreadsheet user has respectively clicked with the 
pointing device 105 on the option button 2310, or 2309, or 2308. Then control is 
given to step 2405. 

• At step 2409, a test is performed to check the value of the local variable 
25 STCopyM_mode. 

• If this local variable is found equal to "range", then control is given to step 
2414; 

• if it is found equal to "instance", then control is given to step 2412; 

• if it is found equal to "element", then control is given to step 2410. 
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• At step 2410, some global variables are initialised. In a prefen-ed embodiment of 
the present invention, these global variables are preferably recorded as part of 
the main memory 102, but any other similar recording means could be used 
instead without departing from the spirit of the invention. 

5 • The global variable Copyjfnode is initialised with the value "element^. 

• The global variable Copy^name is initialised with the value of the local variable 
STCopyM^name. 

• The global varijable Copyjoffset \s initialised with the value of the local variable 
STCopyM^offset 

. 10 ♦ The global variable Copy_body is initialised with the value of the local variable 
STCopyM_body 

• The global variable Copy^element is Initialised with the value of the local 
variable STCopyM_element. 

• At step 2411, the currently selected range of cells is reshaped so that it first 
15 occupies all the columns and only the columns of the scalable template instance 

STCopyMJn$tance_range and second does occupy all rows inside and hot any 
row outside the intersection of the scalable template • instance 
STCopyMJnstance^range with the previous position of the selected rarige of 
cells. Then the currently selected cell becomes the top left cell of this reshaped 
20 .: currently selected range of cells. 

• At step 2412, some global variables are initialised. In a prefen^ed embodiment of 
the present invention, these global variables are preferably recorded as part of 
the main memory 102, but any other similar recording means could be used 
instead without departing from the spirit of the invention. 

25 • The global variable Copy^mode is initialised with the value "instance". 

• The global variable Copy^name Is initialised with the value of the local variable 
STCopyM_name, 

• The global variable Copy_offset is initialised with the value 0 (respectively 1) if 
the scalable template instance STCopyMJnstance^range is qualified as 

30 critical (respectively not critical), as specified by the "CriticaP field 755 of the 
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record 751 within the STIT table 750 corresponding to this scalable template 
instance, field taking respectively the values W and 'Ves". 

• The global variable Copyjbody is initialised with the value of the local variable 
STCopyM_body. 

• The global variable Copy^element is initialised with the value 0 (zero). 

At step 2413, the cun-ently selected range of cells is. reshaped so that it occupies 
the same rows and columns than the scalable template instance 
STCopyMJnstance^range. Then the STIT table 750 is updated by first removing 
any record 751 whose ""Addressl' field 752 is found equal to "clipboard", then by 
duplicating field by field the record 751 whose ''Addres^' field 752 is equal to the 
address of the range of cells STCopyMJnstance^range, and then by replacing in 
this newly created record 751 the "Addres^' field content by the value "cupboard". 
Then control is given to step 2415. 

At step 2414, some jglobal variables are initialised. In a preferred embodiment of 
the present invention, these global variables are preferably recorded as part of 
the main memory 102, but any other similar recording means could be used 
instead without departing from the spirit of the invention. 

• The global variable Copy_mode is initialised with the value "range". 

• The global variable Copy_name is initialised with the value (empty character 
string). 

• The global variable Copy^offset is initialised with the value 0 (zero). 

• The global variable Copyjbody is initialised with the value 0 (zero). 

• The global variable Copy^element is initialised with the value 0 (zero). 

At step 2415, a conventional Copy operation is performed from, the currently 
selected range of cell onto the clipboanJ. 

At step 2416, the Scalable Template Instance Copy Manager Dialog Box 2300 is 
closed (if it was opened) and then control is given back to the initial step 2401 for 
processing any future Scalable Template Instance Copy Manager command. 



236 



wo 03/ni4<)«7 PCT/EP02/09483 

E10. Scalable Template Instance Cut Manager method 

The method for perfomiing a cut operation on a source scalable template instance 
used in a prefened embodiment of the present invention is summarised in flowchart 
2420 of FIG 24B. This method can be seen as the processing of the Scalable 
2 Template Instance Cut Manager command. 

• At step 2421 , the method is in its defaujt state; waiting for an event to initiate the 
process. 

• At step 2422, the Scalable Template Inistance Cut Manager command is 
. detected, as a result of an user action. This action can be for instance a specific 

10 combination of key on the keyboard 104, or the click of the pointing device 105 
on a specific button, or any other similar means hot further specified here. 
When the Scalable Template Instance Cut Manager command is . detected, the 
current spreadsheet selection corresponds to a . range of cells, possibly reduced 
to a single individual cell, which is known as the currently selected range of cells . 

15 and which comprises the currently selected cell. If this; currently selected cell is 
not the top left cell within the currently selected range of cells, then the top left 
cell of the currently selected range of cells becomes the currently selected cell. 

• At step 2423. a test is perfomned to check if the currently selected range of cells 
(referred to as STCutM^range) overlaps any existinig scalable template instance. 

20 This test is performed by parsing the STIT table 750 and. visiting in each record 
751 the ""Acidres^ field 752 to determine if the range of cells address specified in 
this field does overlap the address of the currently selected range of cells 
STCutM^range. If it is the case, then control is given to step 2424 ; othenrt^ise 
control is given to step 2442. 

25 • At step 2424, a test is performed to check if the currently selected cell is located 
within any existing scalable template instance. This test is perfomned by parsing 
the STIT table 750 and visiting in each record 751 the ""Address field 752 to 
detemnine if the range of cells address specified in this field does include the 
address of the individual currently selected cell. If it is the case, then the currently 
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selected cell is contained in a scalable template instance named 
STCutMJnstance_range and control is given to step 2425 ; otherwise control is 
given to step 2426. 

• At step 2425, two local variables STCutM_element and STCutMJnstance are 
S initialised witli the value "enable". Then control is given to step 2427. 

• At step 2426, two local variables STCutM_element and STCutMJnstance are 
initialised with the value "disable", 

• At step 2427, some local variables are initialised. 

• The local variable STCutM_mode takes the default value "range". 

10 • If the local variable STCutMJnstance is equal to "disable", then the local 
variable STCutM_offset takes the value 0 (zero). If the local variable 
STCutMJnstance is equal to "enable", then the local variable STCutM_offset 
takes the value equal to the number of rows between the top row of the 
scalable template instance STCutMjnstance_range and the row of the 

15 cunpently selected cell (for instance if the cunrently selected cell is located on 
the same row as the top row of the scalable template instance 
STCutMJnstance_range, then the local variable STCutM_offset takes the 
value 0). 

• If the local variable STCutMJnstance is equal to "disable", then the local 
20 variable STCutM_name takes the value "none". If the local variable 

STCutMJnstance is equal to "enable", then the local variable STCutM_name 
takes the value of the name of the scaiabje template that the scalable 
template instance STCutMJnstance_range abides by. This name can be 
retrieved from the "ST field 753 within the record 751 of the STIT table 750, 
25 associated to the scalable template instance STCutMJnstance_range. 

• If the local variable STCutMJnstance is equal to "disable", then the local 
variable STCutM_element takes the value 0 (zero). If the local variable 
STCutMJnstance is equal to "enable", then the local variable STCutM_element 
takes the value equal to the number of rows belonging both to the currently 
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selected range of cells and to the scalable template Instance 
STCutMJnstance^range, 

Finally if the local variable STCutMJnstance is equal to "disable", then the 
local variable STCutM^body takes the value 0 (zero). If the local variable 
STCutMJnstance is equal to "enable", then the local variable STCutM_bocly 
takes the value equal to the cun-ent number of elements within the scalable 
template instance STCutMJn$tance_range. This number can be retrieved 
from the "Element r field 754 within the record 751 of. the STIT table 750. 
associated to the scalable template instance STCutMJnstance^range. 

Then several tests are perfomied to evaluate the potential impact of the cut 
operation according to the "range- mode, on any already existing scalable 
teniplate instance. These tests require to parse the STIT table 750, and to visit 
each record 751 to learn the address {""Address^' field 752) and the importance 
{"Criticar field 755) of every already defined scalable template instance. These 
tests evaluate either if two given ranges of cells partially overiap (meaning that 
there exist in the first range of cells at least one cell belonging to the second 
range of cells and at least one cell not belonging to the second range of cells) 
or if a first given range of cells is included within a second given range of cells 
(meaning that every cell belonging to the first range of cells belongs too to the 
second range of cells). Different conventional range comparison techniques 
can be used for evaluating either range partial overiapping or range Inclusion,, 
without departing from the spirit of the present invention; they will not be 
described in the preferred embpdiment of the present Invention. 

If there exists at least one existing scalable template instance whose "Criticar 
field 755 takes the value "yes" and which partially overiaps the currently 
selected range of cells STCutM^range, then the local test variable 
STCutM_range_critical takes the value 'Ves"; othenA^ise the local test variable 
SrCafM„/anflre_c/#/ca/ takes the value "no". 

If there exists at least one existing scalable template instance whose "CriticaP 
field 755 takes the value "no" and which partially overiaps . the currently 
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selected range of cells STCutMjrange, then the local test variable 
STCutM_range_other takes the value "yes"; othenwise the local test variable 
STCutM_range_other^es the value "no". 

At step 2428, the Scalable Template Instance Cut Manager Dialog Box 2320 is 
displayed on the display device 106. The label box 2331 is initialised with the 
nanne of the scalable template that the scajable template instance 
STCutM_name abides by. 
If the local parameter STCutM_element Xakes the value "enable", then the 
option button 2329 Is enabled, meaning that any future click on it with the 
pointing device 105 will be recognised as a valid event. 
If the local parameter STCutM_element takes the value "disable", then the 
option button 2329 Is disabled, meaning that any future click on it with the 
pointing device 105 will not be recognised as a valid event. 
If the local parameter SrCufM_/nsfance takes the value "enable", then the 
option button 2328 is enabled, meaning that any future click on It with the 
pointing device 105 will be recognised as a valid event. 
If the local parameter STCutMJnstance takes the value "disable", then the 
option button 2328 is disabled, meaning that any future click on it with the 
pointing device 105 will not be recognised as a valid event. 
Then if the local variable STCof/MLmoofe takes the nespective value "range", or 
"element", or "instance", then the option button 2330, or 2329, or 2328 displays 
alone a black point. Then the text box 2332 is initialised with the value of the 
local variable STCutM_range_critical. Then the text box 2333 is Initialised with 
the value of the local variable STCutM_range_other. Then the text box 2325 is 
initialised with the value "yes" (respectively "no") if the local variable 
STCutM_range_cn'tical is equal to "no" (respectively "yes"). Then the text box 
2326 is initialised with the value "yes" (respectively "no") if the local variable 
STCutM_element takes the value "enable" (respectively "disable"). Then the 
text box 2327 Is Initialised with the value "yes" (respectively "no") if the local 
variable STCutMJnstance takes the value "enable" (respectively "disable"). 
Finally the "Cuf push-button 2323 is enabled if the text box 2325 shows the 
value "yes" and the option button 2330 shows a black point, or if the text box 
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2326 shows the value "yes" and the option button 2329 shows a black point, or 
if the text box 2327 shows the value "yes" and the option button 2328 shows a 
black point. 

• At step 2429, the method is waiting for any user action on the Scalabte Template 
5 Instance Cut Manager Dialog Box 2320. Such user action is typically resulting 

from a click with the pointing device 105, but take other similar forms such as, 
. but not limited to a specific combination of key on the keyboard 104, or any other 
similar means not further specified here. 

. • At step 2430, a user action on the Scalable Template Instance Cut Manager 
10 Dialog Box 2320 is detected. If the user action is a click on the "Cuf push-button 
2323, then control is given to step 2432; if the user action is a click on one of the 
option buttons 2330, or 2329, or 2328, then control is given to step 2431; if the 
user action is a click on the Cancer push-button 2322, or on the closing-window 
push-button 2321 , then control is given to step 2445. . 

15 • At step 2431, . the local variable STCutM_mode takes the valup "range", or 
"ELEMENf , or "instance", if the spreadsheet user has respectively clicked with the 
pointing device 105 on the option button 2330, or 2329, or 2328. Then control is 
given to step 2428. 

• At step 2432, a . test is performed to check the value of the local variable 
20 STCutM^mode. 

• If this local variable is found equal to "range", then control is given to step 
2442; 

• if it is found equal to "instance", then control is given to step 2437; 

• if it is found equal to "element", then control is given to step 2433. 

25 • At step 2433, some global variables are initialised. In a preferred embodiment of 
the present invention, these global variables are. preferably recorded as part of 
the main memory 102, but any other similar recording means could be used 
instead without departing from the spirit of the invention. 
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• The global variable Copy^mode is Initialised with the value "element". 

• The global variable Copy^name is initialised with the value of the local variable 
STCutM^name. 

• The global variable Copy^offset is initialised with the value of the local variable 
STCutM^offset 

• The global variable CopyjDody Is initialised with the value of the local variable 
STCutM^body. 

• The global variable Copy_element is initialised with the value of the local 
variable STCutM_element 

At step 2434, the currently selected range of cells STCutM^range is reshaped so 
that it first occupies all the columns and ohiy the columns of the scalable 
template instance STCutMJnstance^range and second does occupy all rows 
inside and not any row outside the intersection of the scalable template instance 
STCutMJnstance_range with the previous position of the selected range of cells. 
Then the currently selected cell becomes the top left cell of this reshaped 
currently selected range of cells. 

At step 2435, a conventional Copy operation is perfomned from the currently 
selected range of cell onto the clipboard. 

At step 2436, the "IN" cells belonging to the cunrently selected range of cells 
STCutM^range are cleared. For this purpose, the "ST field 753 of the record 751 
of the STIT table 750, as identified at step 2424, is visited to get a memory 
pointer on the STDT table 760 of the scalable template, which specifies for each 
meta-element and for each element of the scalable template instance what is the 
associated profile, which In turn indicates which cells are "IN" cells, and which 
cells are "OUT" cells. Then each row of the range of cells STCutM^range is 
selected one after the other, and for each selected row, the con-esponding 
element or meta-element profile is retrieved from the STDT table 760 to 
detemiine which cells are "IN" cells. For this purpose, a temporary local variable 
STCutM_out__fields memorises the relative positions of all the cells specified as 
IN" or "OUT" cells, as. an ordered set of in or out values. For instance in an 
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element profile made of 5 cells, where only the third and fifth cells are "OUT 
cells, this local variable STCutM_outJields takes the value (in, in, out, in, out). 
Once the "IN" cells belonging to the range of cells STCutM_range are 
determined, these cells are updated by clearing their content. 

At step 2437, some global variables are initialised. In a prefen^d embodiment of 
the present invention, these global variables are preferably recorded as part of 
the main memory 102, but any other similar recording means could be used 
instead without departing from the spirit of the invention. 

• The global variable Copy_mod9 is initialised with the value "instance". 

• The global variable Copy_name is initialised with the value of the local variable 
. STCutM_name. 

• The global variable Copy_offset is initialised with the value 0 (respectively 1) if 
the scalable template instance STCutMJnstance_range is qualified as critical 
(respectively not critical), as specified by the "Criticar field 755 of the record 
751 within the STIT table 750 corresponding to this scalable template 
instance, field taking respectively the values "no" arid "yes". 

• The global variable Copy_body is initialised with the value of the local variable. 
STCutM_body. 

• The global variable Copy_element is initialised with the value 0 (zeip). 

At step 2438., the currently selected range of cells is reshaped so th3t it occupi^ 
the same rows and columns than the scalable . template instance 
STCutM_instance_range. 

At step 2439, a conventional Cut operation is perfomned from the currently 
selected range of cell onto the clipboard. 

At step 2440, the STIT table 750 is scanned to remove from it any record 751 
whose "Addrss^ field 752 is found equal to the value "clipboard". Each time such 
a record 751 has been removed from the STIT table 750, the "Reference 
Housekeeping Process", as described in step 1414 of the Scalable Template 
Instanciator method, is invoked and executed before looking for any other 
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record 751 to be removed from the STIT table 750. Then control is given to the 
step 2441. 

• At step 2441 , the record 751 within the STIT table 750 whose Mc/cfress?' field 752 
corresponds to the scalable template instance STCutMJnstance^range is 

5 updated by setting the ""Address field 752 to the value "clipboard". 

• At step 2442, some global variables are initialised. In a preferred embodiment of 
the present invention, these global variables are preferably recorded as part of 
the main memory 102, but any other similar recording means could be used 
instead without departing from the spirit of the invention. 

10 • The global variable Copy^mode is initialised with the value "range". 

• The global variable Copy^name is initialised with the value (empty character 
string). 

• The global variable Copy^offset is initialised with the value 0 (zero). 

• The global variable Copy_body is initialised with the value 0 (zero). 

15 • The global variable Copy^element is initialised with the value 0 (zero). 

• At step 2443, the records 751 identified at step 2423 are removed from the STIT 
. table 750. Each time such a record 751 has been removed from the STit table 
; 750, the "Reference Housekeeping Process", as described in step 1414 of the 

• . Scalable Template Instanciator method, is invoked and executed , before 
20 looking for any other record 751 to be removed from the STIT table 750. Then 

control is given to the step 2444. 

• . At step 2444, a conventional Cut operation is performed from the currently 

selected range of cell onto the clipboard. 

• At step 2445, the Scalable Template Instance Cut Manager Dialog Box 2320 is 
25 closed (if it was opened) and then control is given back to the initial step 2421 for 

processing any future Scalable Template Instance Cut Manager command. 

El 1 . Scalable Template Instance Paste method 

244 



wo 03/014987 



PCT/EP02/09483 



The method for performing a paste operation on a destination scalable template 
instance used in a prefered ambodiment of the present invention is summarised in 
flowchart 2450 of FIG 24C. This method can be seen as the processing of the 
Scalable Template Instance Paste Manager command. 

5 • At step 2451 , the method is in Its default state, waiting for an event to initiate the 
process. 

• At step 2452, the Scalable Template Instance Paste Manager command is 
detected, as a result of an user action. This action can be for instance a specific 
combination of key on the keyboard 104, or the click of the pointing device 105 

10 on a specific button, or any other similar means not further specified here. 

When the Scalable Template Instance Paste Manager command is detected, 
the current spreadsheet selection corresponds to a range of cells, possibly 
reduced to a single individual cell, which is known as the currently selected range 
of cells and which comprises the currently selected cell. If this currently selected 

15 cell is not the top left cell within the currently selected range of cells, then the top 
. left cell of the currently selected range of cells becomes the cun-ently selected 
cell. . 

• At step 2453, the destination range of cells, refen^ed to as desLrange, is 
detemiined according to a conventional method. 

20 • If the previously copied or cut range of cells is made of a single column and of 
multiple rows, then dest^range con'espohds to a range of cells occupying the 
same columns as the currently selected range of cells, and occupying as many 
rows as the range of cells previously copied or cut. 

• If the previously copied or cut range of cells is made of a single row and of . 
25 multiple columns, then dest^range corresponds to a range of cells occupying 

the same rows as the currently selected range of cells, and occupying as 
many columns as the range of cells previously copied or cut. 

• If the previously copied or cut range of cells is made of a single cell, then 
desLrange corresponds to the currently selected range of cells. 
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• In all the other cases, clest_range occupies as many rows and columns as the 
previously copied or cut range of cells, with the top left cell located on the 
position of the cumently selected cell. 
Then some local variables are initialised: the local variable STPasteM_mode is 
S Initialised to the value "range"; the local variable STPasteM_element is initialised 
to the value "disable"; and the local variable STPasteMJnstance is initialised to 
the value "disable". 

• At step 2454, a test is performed to check if the range of cells dest.ranpe 
overlaps any existing scalable template instance. This test is performed by 

10 parsing the STIT table 750 and visiting in each record 751 the "Address field 
752 to detemiine if the range of cells address specified in this field does overlap 
the address of the range of cells dest_range. If it is the case, then control is given 
to step 2458 ; othenwise control is given to step 2455. 

• At step 2455, a conventional Paste operation is performed from the. clipboard 
.15 onto the range of cells c/esLrange. 

• At step 2456, a test is perfomied to checl< the value of the global variable 
copy_mode. If the value of this global variable is found equal to "instance", then 
control is given to step 2457; othenwise control is given to the Initial step 2451 for 
processing any future Scalable Template Instance Paste Manager command. 

20 • At step 2457, the STIT table 750 is updated. The record 751 whose "Address 
field 752 is found equal to "clipboard" is first duplicated field by field and then this 
just created new record 751 is updated by setting the "Address field 752 to the 
address of the range of cells dest_range. Then control is given to the initial step 
2451 for processing any future Scalable Template Instance Paste Manager 

25 command. 

• At step 2458, a test is perfonned to checl< the value of the global variable 
copy_mode. If the value of this global variable is found equal to "range", then 
control is given to step 2459; othenvise control Is given to step 2460. 
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At step 2459, a test is performed to check if the overlap area between the range 
of cells dest^range and existing scalable template instances (as identified at step 
2454) does comprise element or meta-element cells specified as ''OUF cells. If it 
is the case, then control is given to step 2478; othenAnse control is given to step 
2477. 

At Step 2460, a test is perfomied to check if the cun^ently selected cell is located 
within any existing scalable template instance. This test is perfomned by parsing 
the STIT table 750 and visiting in each record 751 the "Address field 752 to 
detenmine if the range of cells address specified in this field does include the 
address of the individual currently selected cell. If it is the case, then the currently 
selected cell is contained in a scalable template instance named 
StPasteMJnstance_range arid control is given to step 2461 ; othenwise control, 
is given to step 2459. 

At step 2461, a test is perfonned to check the value of the global variable 
copy^mode. If the value of this global variable is found equal to "element, then 
control is given to step 2462;. othenA^ise control is given to step 2463. 

At step 2462, a test is perfomied to check If there is any mismatch between the 
structure of the elements or meta-elements which were previously copied or cut 
onto the clipboard (referred to as the source element structure which is. 
characterised by the global variable copy^name, by the global variable 
copy^offset, by the global variable copy^element and by the global variable 
copy^bod^ and the structure of the elenients or meta-elements within the 
scalable template Instance STPasteMJnstance_range which occupy the rows of 
the range of cells dest^range (referred to as the destination element structure 
which is cha;racterised by the "ST field 753 of the associated record 751 within 
the STIT table 750, by the relative row offset between the range of cells 
desLrange and the range of cells STPasteMJnstance_range, and by the 
"Element #' field 754 of the associated record 751 within the STIT table 750). 
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These two structures are found as different if one or both of the two following 
conditions are fulfilled: 

• The global variable copy_offset Is less than the ''Header Sizd' field 756 and 
the global variable copy^offset Is different from the relative row offset between 

5 the range of cells dest_range and the range of cells 
STPasteMJn$tance_range, 

• The sum of the global variables copy_offset and copy^element Is greater than 
the sum of the "Header Siz^ field 756 and of the global variable copy^body 
and the difference between the global variables copyjDody and copy_offset is 

10 different from the difference between the ""Element #' field 754 and the relative 
row offset between the range of cells dest_range and the range of cells 
STPasteMJn$tance__range, 
If both structures are found different (according to the above conditions) then 
control is given to step 2478; othenwise control Is given to step 2464. 

15 • At step 2463, a test is perfomied to check if there is any mismatch between the 
size of the scalable template instance which was previously cojDied or cut onto 
the clipboard (referred to as the source scalable template instance which is 
characterised by the global variable copy^name, by. the global variable 
copy_offset and by the global variable copy^body) and the scalable template 

20 Instance STPasteMJnstance_range (referred to as the destination scalabte 
template instance element stmcture which Is characterised by the "Sr field 753 
of the associated record 751 within the STIT table 750, by the "Crrtical" field 755 
of the associated record 751 within the STIT table 750, and by the ""Element 
field 754 of the associated record 751 within the STIT table 750). If both 

25 instances have the same size (same number of rows and columns) then control 
is given to step 2465; othenwise control is given to step 2478. 

• At step 2464, the local variable STPasteM^element is initialised to the value 
"enable", then control is given to step 2478. 

• At step 2465, the local variable STPasteMJnstance Is Initialised to the value 
30 "enable", then. control is given to step 2478. 
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• At Step 2466, the Scalable Template Instance Paste Manager Dialog Box 2340 Is 
displayed on the display device 106. The label box 2351 is Initialised with the 
name of the scalable template that the scalable template instance 
STPa$teMJnstance_name abides by. The label box 2354 Is initialised with the 
S value of the global variable copy.name. 

• If the local parameter STPasteM_element takes the value "enable", then the 
push-button 2349 is enabled, meaning that any future click on it with the 
pointing device 105 will be recognised as a valid eyent. 

• If the local parameter STPasteM^element takes the value "disable", then the 
10 push-button 2349 is disabled, meaning that any future click on it with the 

pointing device 105 will not be recognised as a valid event. 

• if the local parameter STPasteMJnstance takes the value "enable", then the 
push-button 2348 is enabled, meaning that any future click on it .with , the 
pointing device 105 will be recognised as a valid event. 

15 • If the local parameter STPasteMJnstance takes the value "disable", then the 
push-button 2348 is disabled, meaning that any future click on it with the. 
pointing device 105 will not be recognised as a valid event. 

Then if the local variable STPasteM_mode takes the respective value "range", or 
"element", or "instance", then the option button 2350, or 2349, or 2348 displays 

20 alone a black point. Then the text box 2352 is initialised with the value of the 
local variable STPasteM_range_critical, Then the text box 2353 is initialised with 
the value of the local variable STPasteM_range_other. Then the text box 2345 is 
initialised with the value "yes" (respectively "no") if the local variable 
STPasteM_range_critical is equal to "no" (respectively \es"). Then the text box 

25 2346 is initialised with the value ^es" (respectively "no") if the local variable 
STPasteM_element takes the value "enable" (respectively "disable"). Then the 
text box 2347 is initialised with the value "yes" (respectively "no") if the local 
variable STPasteMJnstance takes the value "enable" (respectively "disable"). 
Finally the "Pasfe^' push-button 2343 is enabled if the text box 2345 shows the 

30 value "yes" and the option button 2350 shows a black point, or If the text box 
2346 shows the value "yes" and the option button 2349 shows a black point, or If 
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the text box 2347 shows the value "yes" and the option button 2348 shows a 
black point. 

• At step 2467, the method is waiting for any user action on the Scalable Template 
Instance Paste Manager Dialog Box 2340. Such user action is typically resulting 

.5 from a click with the pointing device 105, but take other isimllar fomis such as, 
but not limited to a specific combination of key on the keyboard 104, or any other 
similar means not further specified here. 

• At step 2468, a user action on the Scalable Template Instance Paste Manager 
Dialog Box 2340 is detected. 

10 • If the user action is a click on the "Pasfe" push-button 2343, then control is 
given to step 2470; 

• if the user action is a click on one of the option buttons 2350, or 2349, or 2348, 
then control is given to step 2469; 

• if the user action is a click on the "Cancer push-button 2342, or on the 
15 closing-window push-button 2341 , then control is given to step 2476. 

• At step 2469, the local variable STPa$teM_mode takes the value "range", or 
"ELEMENf , or "instance", If the spreadsheet user has respectively clicked with the 
pointing device 105 on the option button 2350, or 2349, or 2348. Then control is 
given to step 2466. 

20 • At step 2470, a test is perfomied to check the value of the local variable 
STPasteM_mocle, 

• If this local variable is found equal to "range", then control .is given to step 
2471; 

• if it is found equal to "instance", then control is given to step 2473; 
25 • if it is found equal to "element, then control is given to step 2472. 

• At step 2471 , the records 751 identified at step 2478 are removed from the STIT 
table 750. Each time such a record 751 has been removed from the STIT table 
750, the "Reference Housekeeping Process", as described in step 1414 of the 
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Scalable Template Instanciator method, is invoked and executed before 
looking for any other record 751 to be removed from the STIT table 750. Then 
control is given to the step 2475. 

At step 2472, the range of cells desLrange is reshaped so that It first occupies 
all the columns and only the columns of the scalable template instance 
STPasteMJnstance_range and second does occupy all rows inside and not any 
row outside the intersection of the scalable template instance 
STPasteM_instanc0_range with the previous position of the range of cells 
desL.range, Then the cunrently selected cell becomes the top left cell of this 
reshaped range of cells. Then control is given to step 2475. 

At step 2473, the STIT table 750 is updated. First the record 751 whose 
"Address' field 751 is found equal to the address of the range of cells 
STPasteMJnstance_range is deleted. Second the record 751 whose "Address 
field 752 Is found equal to "clipboard" is first duplicated field by field an then the 
just created new record 751 is updated by setting in the "Address fie\d, 752 the 
address, of the range of cells SrPasf©M_/nsfanc8_ranflfe. 

At step 2474, the range of cells dest_range is reshaped to occupy the same 
position than the range of cells STPasteMJnstance_range. 

At step 2475, a conventional Paste operation is perfomned from the clipboard 
onto the range of cells dlesLranpe. 

At step 2476, the Scalable Template Instance Paste Manager Dialog Box 2340 is 
closed and then control is given back to the initial step 2451 for processing any 
future Scalable Template Instance Paste Manager command. 

At step 2477, a conventional Paste operation by content is perfomned from the 
clipboard onto the range of cells dest_range and then control Is given back to the 
initial step 2451 for processing any future Scalable Template Instance Paste 
Manager command. 
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• At step 2478, several tests are performed to evaluate the potential impact of the 
paste operation according to the "range" mode, on any already existing scalable 
template instance. These tests require to parse the STIT table 750, and to visit 
each record 751 to learn the address (Mcfafress^ field 752) and the importance 
5 C'Criticar field 755) of every already defined scalable template instance. These 
tests evaluate either if two given ranges of cells partially overlap (meaning that 
there exist in the first range of cells at least one cell belonging to the second 
. range of cells and at least one cell not belonging to the second range of cells) or 
if a first given range of cells is included within a second given range of cells 
• 10 . (meaning that every cell belonging to the first range of cells belongs too to the 
second range of cells). Different conventional range comparison techniques can 
be used for evaluating either range partial, overlapping or range inclusion, without 
departing from the spirit of the present invention; they will not be described in the 
preferred embodiment of the present invention: 

15 

If there exists at least one existing scalable template instance whose "Criticar 
field 755 takes the value 'Ves" and which partially overlaps the range of cells 
dest^range, then the local test variable STPasteM_range_criticalXakBs the value 
\es"; othenwise the local test variable STPasteM_range_critical takes the value 
20 W. 

If there exists at least one existing scalable template Instance whose "Criticar 
field 755 takes the value "no" and which partially overiaps the range oif cells 
dest^range, then the local test variable STPasteM_rangB_other takes the value 
. 25 'Ves"; othenwise the local test variable STPasteM_range_other takes the value 
. "no". Then control is given tp step 2466. 

E12. Scalable Template Export Manager method 

The method for exporting the definitiofi of scalable template objects (either element 
fomiats, or element profiles, or meta-element formats or meta-element profiles or 
30 scalable templates) from a source spreadsheet file to a destination export-import 
spreadsheet file used in a preferred embodiment of the present invention is 
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summarised in flowchart 2500 of FIG 25A. This method can be seen as the 
processing of the Scalable Template Export Manager command. 

• At step 2501 , the method is in its default state, waiting for an event to initiate the 
process. 

. 5 • At step 2502, the Scalable Template Export Manager command is detected, as 
a result of a user action. This action can be for instance a specific combination.of 
key on the keyboard 104, or the click of the pointing device 105 ori a specific 
button, or any other similar means not further specified herB. 

• At step 2503, the Scalable Template Export Manager Dialog Box 2600 .1s 
10 displayed on the display device 106. At this stage of the Scalable Template 

Export Manager method, the Scalable Template Export Manager Dialog Box 
2600 contains only three push-buttons: the push-button "Export in a NEW fiW 
2612, the push-button 'Export in an EXISTING fil^ 2613, and the push-button 
"Cancer 2602. 

15 • At step 2504, the method is waiting for any user action on the Scalable Template 
Export Manager Dialog Box 2600, Such user action is typically resulting from a 
click with the pointing device 105, but take other similar fornis such as, but not 
limited to a specific combination of key on the keyboard 104, or any other similar 
means not further specified here. 

20 • At step 2505, a user action on the Scalable Template Export Manager Dialog 
Box 2600 is detected. 

• If the user action is a click on the push-button "Export in a NEW fil^' 2612, 
then control is given to step 2507; 

• if the user action is a click on the push-button "Export in an EXISTING fHef' 
25 2613, then control Is given to step 2508; 

• if the user action is a click on the push-button "Cancer 2602, or on the 
closirig-window push-button 2601 , then control is given to step 2506. 
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• At Step 2506, the Scalable Template Export Manager Dialog Box 2600 is closed 
and then control is given back to the initial step 2501 for processing any future 
Scalable Template Export Manager command. 

• At step 2507, conventional means are used to interface with the spreadsheet 
5 user for creating the new spreadsheet export-import file to be created. In a 

preferred embodiment of the present invention, these means correspond to a 
conventional file creation dialog box displayed on the display device 106, but any 
other similar conventional means could be used instead without departing from 
the spirit of the invention. Furthemiore no specific assumption is made regarding 
10 the file structure used In the environment where the spreadsheet application is 
running, as any conventional file structure can be used without influencing the 
spirit of the invention. Then control is given to step 2512. 

• At step 2508, conventional means are used to interface with thQ spreadsheet 
user for retrieving the existing spreadsheet export-import file to be updated. In a 

15 preferred embodiment of the present invention, these means correspond to a 
conventional file selection dialog box displayed on. the display device 106, but 
any other similar conventional means could be used instead without departing 
from the spirit of the Invention. Furthermore no specific assumption is rnade 
regarding the file structure used in the environment where the spreadsheet 

20 application is running, as any conventional file structure can be used without 
influencing the spirit of the Invention. 

• At step 2509. a test is perfomied to check if the file identified at step 2508 is a 
valid spreadsheet export-import file. This validity test corresponds to verifying 
that the identified spreadsheet file follows the logical file structure 2640 illustrated 

25 by the FIG 26C, which is made of three parts. 

• The first part 2641 is the spreadsheet export-import file header containing a 
unique signature identifying a spreadsheet export-import file. 

• The second part 2642 is made of a table following the structure of a STEIT 
table 770, as illustrated by FIG 7G. 
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• The third and last part 2643 is the Descriptor area where are recorded the 
descriptions of the scalable template items (either element formats, or element 
profiles, or meta-element formats or meta-element profiles or scalable 
templates) pointed by the ""Description Rf field 774 within the records 771 of 
the STEIT-like table recorded within the second part 2642 of the spreadsheet 
export-import file. 

If the spreadsheet file follows this logical file structure 2640, then control is given 
to step 251 1 ; othenAnse control is given to step 251 0. 

At step 2510, a warning, message notification is issued for informing the user that 
the selected spreadsheet file does not comply with the structure of spreadsheet 
export-import files. This can typically be done by displaying on the display device 
106 a warning message in a pop-up window, or in a status bar area, but any 
other similar means could be used instead, without departing from the spirit of 
the invention. Once the user has acknowledged this notification message 
through conventional means such as clicking with the pointing device 105 on an 
"OK" push-button present within a warning message pop-up window, or any other 
similar means without departing from the spirit of the invention, control is given to 
step 2503. 

At step 2511, the second and third parts 2642 and 2643 of the selected file are 
loaded into memory to constitute the STEIT table 770 and the associated object 
descriptions. Then some local variables are initialised: 

• the local variable STEMJndexl is initialised to the value 1 (one); 

• the local variable STEM^replace^all is initialised to the value "no"; 

• the local variable STEM^STMT_$ize is initialised to the number of records 731 
within the STMT table 730; 

• the local variable STEM_STEIT_size is initialised to the number of records 771 
within the STEIT table 770. 

Then control is given to step 2513. 

At step 2512, an empty STEIT table 770 is created in memory as well as the 
associated memory space for recording the descriptions of the scalable template 
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items described by records 771. Then some local variables are initialised: the 
local variable STEMJndexl is Initialised to the value 1 (one); the local variable 
STEM^replace^all is initialised to the value "no"; the local variable 
STEM_STMT_size is initialised to the number of records 731 within the STMT 
5 table 730; the local variable STEM^STELsize is initialised to 0 (zero). 

• At step 2513, the Scalable Terhplate Export Manager Dialog Box 2600 is 
refreshed on the display device 106, as the text box 2603 specifies the name of 
the file to which are exported scalable template items, and as the progression 
bar 2604 is displayed to reflect the fact that the currently processed record of the 

10 STMT table 730 is the one of rank STEMJndexl out of a set of size 
STEM^STMT^size. 

• At step 2514, within the STMT table 730, the record 731 whose "//ideA" field 738 
has a value equal to the value of the local variable STEMJndexl, becomes the 
cun^ent record STEM_STMT_rec 731 of the STMT table 730. 

15 • At step 2515, a test is perfonmed on the STEM^STMT_rec record 731 tb 
detennine if the value of the "selected" attribute 742 within the "TypeT field 737 is 
equal to *Ves". If it is the case, then control is given to step 2517; othenwise 
control is given to step 2516. 

• At step 2516, a test is perfonmed to check if the value of the local . variable 
20 STEMJndexl is greater than or equal to the value of the local variable 

STEM_STMT_size, If it is the case, then control is given to step 2528; othenA^ise 
control is given to step 2527. 

• At step 2517, the local variable STEMJndex2 \s initialised to the value 1 (one). 

• At step 2518, within the STEIT table 770, the record 771 whose "Inde)^ field 778 
25 has a value equal to the value of the local variable STEMJndex2, becomes the 

current record STEM^STEIT^rec 771 of the STEIT table 770. 
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• At Step 2519, a test is performed to check if tlie value of the "Nam^ field 732 of 
the STEM_STMT_rec record 731 is equal to the value of the "A/ame^ field 772 of 
the STEM_STEIT_rec record 771. If it is the case, then control is given to step 
2521 ; othePAnse control is given to step 2520. 

5 • At step 2520, a test is performed to check if the value of the local variable 
STEMJndex2 is. greater than or equal to the value of the local variable 
STEM_STEIT_size. If it is the case, then control is given to step 2523; otherwise 
control is given to step 2522. 

• At step 2521 , a test is perfomied to check if the local variable STEM_replace_all 
10 is equal to the value "yes". If it is the case, then control is given to step 2525; 

othenvise control is given to step 2524. 

• At step 2522, the local variable STEMJndex2 is incremented by 1 (one) and 
then control is given to step 2518. 

• At step 2523, a new record 771 is created In the STEIT table 770. This new 
1.5 record is initialised wHhin each field 772, 773, 775, 776, 777 and 778 with the 

content of the respective fields 732, 733, 735; 736. 737 and 738 within the 
STEM_STMT_rec record 731. In addition the scalable template item description, 
as pointed by the "Description Ptf field 734 is copied within the Descriptor Area 
2643, and the "Description Ptf field 774 of the STEM_STEIT_rec record 731 is 
2D set to the memory address of this copied descriptor. Then control is given to step 
2516. 

• At step 2524; the Scalable Template Export Manager Dialog Box 2600 is 
updated by displaying in a frame 2611 some infomnation related to a conflict 
between a record already existing in the STEIT table 770 and a record exported 

25 from the STMT table 730. Both records con*espond to the same scalable 
template item whose name Is displayed In the text box 2605. The STEIT record 
771 is time stamped with the date displayed In the text box 2606, and the STMT 
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record 731 is time stamped witli a date displayed In the text box 2607. The 
spreadsheet user maltes one choice out of three: 

• If he/she wants to replace the existing definitions based on the STEIT table 
770 by the definitions based on the STMT table 730 for all the scalable 
template Items, then he/she click with the pointing device 105 on the "Yes to 
Air push-button 2609 and control is given to step 2526; 

• If he/she wants to replace the existing definition based on the STEIT table 770 
by the definition based on the STMT table 730 for the current scalable 
template Item, then he/she click with the pointing device 105 on the "Ye^' 
push-button 2610 and control is given to step 2525; 

• If he/she does not want to replace the existing definition based on the STEIT 
table 770 by the definition based on the STMT table 730 for the cun-ent 
scalable template item, then he/she click with the pointing device 105 on the 
"Ncf push-button 2608 and control Is given to step 251 6. 

In all the three cases, the frame 2611 and the objects it contains are no longer 
displayed on the display devtee 106 as soon as the spreadsheet user clicks with 
the pointing device 105 on one of the three push-buttons 2608, 2609, and 261.0. 

At step 2525, the STEM_STEIT_rec record 771 within the STEIT table 770 is 
replaced field by field by the STEM_STMT_rBC record 731: the content of each 
field 772, 773, 775, 776, 777 and 778 is replaced by the content of the respective 
fields 732, 733, 735, 736, 737 and 738 from the STEM_STMT_rec record 731 . In 
addition the scalable template item description, as pointed by the "Description 
Ptr field 734 is copied within the Descriptor Area 2643 at the address pointed by 
the "Description Pti" field 774 of the STEM_STEIT_rec record 731. Then control 
is given to step 2516. 

At step 2526, the local variable STEI\/l_replace_aH Is set equal to the value "yes" 
and then control Is given to step 2525. 

At step 2527, the local variable STEMJndexl Is incremented by 1 (one) and 
then control Is given to step 2513. 
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• At Step 2528, the STEIT table 770 and the associated descriptions are saved on 
the current export-Import file to respectively constitute the updated second part 
(STEIT-IIke table) 2642 and the updated third part (Descriptpr Area) 2643 of the 
logical stmcture 2640 followed by the export-import file. Then, control is given to 

S step 2506. 

El 3. Scalable Template Import Manager method 

The method for importing the definition of scalable template objects (either element 
formats, or element profiles, or meta-element formats or meta-element profiles or 
scalable templates) from a source import-export spreadsheet file to a destination 
10 spreadsheet file used in a preferred embodiment of the present invention is 
summarised in flowchart 2530 of FIG 25B. This method can be seen as the 
processing of the Sca/ai>/e Temp/aJe //npo/f Ma/iaflrer command. 

• At step 2531 , the method is in its default state, waiting for an event to initiate the 
process. 

15 • At step 2532, the Scalable Template Import Manager command is detected, as 
a result of a user action. This action can be for instance a specific combination of 
key on the keyboard 104, or the click of the pointing device 105 on a specific 
button, or any other similar means not further specified here. 

• At step 2533, the Scalable Template Import Man€iger Dialog Box 2620 is 
20 displayed on the display device 106. At this stage of the Scalable Template 

Import Manager method, the Scalable Template Import Manager Dialog Box 
2620 contains only two push-buttons: the push-button "Select an Import fll^ 
2632, and the push-button "Cancer 2622. 

• At step 2534, the method is waiting for any user action on the Scalable Template 
25 Import Manager Dialog Box 2620. Such user action is typically resulting from a 

click with the pointing device 105, but take other similar forms such as, but not 
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limited to a specific combination of l<ey on the l<eyboard 104, or any other similar 
means not further specified here. 

At step 2535, a user action on the Scalable Template Import Manager Dialog 
Box 2620 is detected. If the user action is a click on the push-button ''Select an 
Import fil^ 2632, then control is given to step 2537. If the user action is a click on 
the push-button "Cancer 2622, or on the.closing-window push-button 2621, then 
control is given to step 2536. 

At step 2536, the Scalable Template Import Manager Dialog Box 2620 is closed 
and then control is given back to the. initial step 2531 for processing any future 
Scalable Template Import Manager command. 

At step 2537, conventional means are used to interface with the spreadsheet 
user for retrieving the existing spreadsheet export-import file to be accessed. In a 
preferred embodiment of the present invention, these means correspond to a 
conventional file selection dialog box displayed on the display device 106, but 
any other similar conventional means could be used instead without departing 
from the spirit of the invention. Furthemriore no specific assumption is madq 
regarding the file strticture used in the environment where the spreadsheet 
application is running, as any conventional file structure can be used without 
influencing the spirit of the invention. 

At step 2538, a test is performed to check if the file identified at step 2537 is a 
valid spreadsheet export-import file. This validity test corresponds to verifying 
that the spreadsheet file follows the logical file stmcture 2640 illustrated by the 
FIG 26C, which is made of three parts. The first part 2641 is the spreadsheet 
export-import file header containing a unique signature identifying a spreadsheet 
export-import file. The second part 2642 is made of a table following the structure 
of a STEIT table 770, as illustrated by FIG 7G. The third and last part 2643 is the 
Descriptor area where are recorded the descriptions of the scalable template 
items (either element fomnats, or element profiles, or meta-element formats or 
meta-element profiles or scalable templates) pointed by the "Description Ptf field 
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774 within the records 771 of the STEIT-like table recorded within the second 
part 2642 of the export-Import file. If the file follows this logical file structure 2640, 
then control is given to step 2540; othenAfise control is given to step 2539. 

• At step 2539, a warning message notification Is issued for infonning the user that 
S the selected spreadsheet file does not comply with the structure of spreadsheet 

export-import files. This can typically be done by displaying on the display device 
106 a warning message in a pop-up windpw, or in a status bar area, but any 
other siniilar means could be used instead, without departing from the spirit of 
the invention. Once the user has acknowledged this notification message 
10 through conventional means such as clicking vyith the pointing device 105 on an 
"OK" push-button present within a warning message pop-up window, or any other 
similar means without departing from the spirit of the invention, control is given to 
step 253i3. 

• At step 2540, the second and third parts 2642 and 2643. of the selected file are 
15 loaded into memory to constitute the STEIT table 770 and the associated object 

descriptions. Then some local variables are initialised: 

• the local variable STIMJndexl is initialised to the value 1 (one); 

• the local variable STIM^replace^all is initialised to the value "no"; 

• the local variable STIM_STMt_sizB is initialised to the number of records 731 
20 within the STMT table 730; 

• . the local variable STIM_STEIT_size is initialised to the number of records 771 
. within the STEIT table 770. 

• At step 2541 , the Scalable Template Import Manager Dialog Box 2620 is 
refreshed on the display device 106, as the text box 2623 specifies the name of 

25 the file from which are imported scalable template items, and as the progression 
bar 2624 is displayed to reflect the fact that the currently processed record of the 
STEIT table 770 is the one of rank STIMJndexl out of a set of size 
STIM^STEIT^size. 
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• At Step 2542, within the STEIT table 770, the record 771 whose "/ndey field 778 
has a value equal to the value of the local variable STIMJndexl, becomes the 
current record STIM_STMT_rec 771 of the STEIT table 770. 

• At step 2543, the local variable STIMJndex2 is Initialised to the value 1 (one). 

5 • At step 2544, within the STMT table 730, the record 731 whose "/nofeA" field 738 
has a value equal to the value of the local variabie Sr/M_/hdex2, becomes the 
current record STIM_STMT_rec 731 of the STMT table 730. 

• At step 2545, a test is performed to check if the value of the "Nam^ field 732 of 
the STIM_STMT_rec record 731 is equal to the value of the "NameT field 772 of 

10 the STIM_STEIT_rec record 771. If it is the case, then control is given to step 
2555; othenATise control is given to step 2546. 

• At step 2546, a test is perfomied to check if . the value of . the local variable 
STIM_index2 is greater than or equal to the value of the local variable 
STIM_STMT_siz0. If It is the case, then control is given to step 2549; othenwise 

15 control is given to step 2548. 

• At step 2547, a test is perfonmed to check if the local variable StlM_replace_all 
is equal to the value "yes". If it is the case, then control is given to step 2j55b; 
othenwise control is given to step 2551 . 

• At step 2548, the local variable STIM_index2 is incremented by 1 (one) and then 
20 control is given to step 2544. 

• At step 2549, a new record 731 is created in the STMT table 730. This new 
record Is initialised within each field 732, 733, 735, 736, 737 and 738 with the 
content of the respective fields 772, 773, 775, 776, 777 and 778 within the 
STIM_STEIT_rec record 771. In addition the scalable template item description, 

25 as pointed by the "Description Ptf field 774 is copied in memory, and the 
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"Description Ptf field 734 of the new record 731 is set to the memory address of 
this copied descriptor. Then the "nature" attribute .741 of the "Typ^ field 737 of 
the new record 731 Is retrieved to detemilne In which table (EFT 700, or EPT 
710, or STT 720) a new record must also be created. If this "nature" attribute is 

5 found equal to "format" (respectively ^tempute", or "profile"), then a new record 
701 (respectively 711 or 721) is created in the EFT table 700 (respectively EPT 
table 710 or STT table 720), where tfie fields 702, 703, 704, 705, 706, 708, 709 
(respectively 712, 713, 714, 715, 716, 718, 719 or 722, 723, 724, 725, 726, 728, 
729) are initialised with the content of the fields 732, 733, 734, 735, 736,. 739, 

10 740 of the new record 731 . Then control is given to step 2553. 

. 'At step 2550, the STIM_STMT_rec record 731 within the STMT table 730 is 
replaced field by field by the STIM_STEIT_rec record 771: the content of each 
field 732, 733, 735, 736. 737 and 738 is replaced by the content of the respective 
fields 772, 773, 775, 776, 777 and 778 from the STlM_STEIT_rec record 771. In 

15 addition the scalable template Item description, as pointed by the "Description 
Ptf field 774 is copied from the Descriptor Area 2643 at the address pointed by 
the "Description Ptf field 734 of the STIM_STMT_rec record 731. Then the 
"nature" attribute, 741 of the "Typ^ field 737 of the updated record 731 is 
retrieved to detennine in which table (EFT 700, or EPT 710, or STT 720) a 

20 record must also be updated. If this "nature" attribute is found equal to "format" 
(respectively "template", or "profile"), then the record 701 (respectively 711 or 
721) in the EFT table 700 (respectively EPT table 710 or STT table 720), whose 
"A/ame^ field 702 (respectively 712 or 722) is found equal to the "A/ame" field 732, 
is updated as the fields 703, 704, 705, 706, 708, 709 (respectively 713, 714, 715, 

25 71 6, 71 8, 71 9 or 723, 724, 725, 726, 728, 729) are replaced by the content of the 
fields 733, 734, 735, 736, 739, 740 of the updated record 731 . 
At this stage, the method can optionally be completed by invoking ihe Scalable 
Template Refresh Manager command, so that the update of the imported 
object (either a profile or a fonnat according to the "nature" attribute) be reflected 

30 in every scalable template instance that abides by a scalable template whose 
definition refers to the imported fomiat or profile, as recorded In records 701 or 
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710 of the EFT table 700 or EPT table 710. The necessary steps followed for 
executing the Scalable Template Refresh Manager command are not recalled 
here as they have been already extensively described in a former section. 
Then control is given to step 2553. 

At step 2551. the Scalable Template Import Manager Dialog Box 2620 Is 
updated by displaying in a frame 2631 some infonnation related to a conflict 
between a record already existing in the STMT table 730 and a record imported 
from the STEIT table 770. Both records correspond to the same scalable 
template item whose name is displayed in the text box 2625. The STEIT record 
771 is tirtie stamped with the date displayed in the text box 2627, and the STMT 
record 731 is time stamped with a date displayed in the text box 2626. The 
spreadsheet user makes one choice out of three: 

• if he/she wants to replace the existing definitions based on the STMT table 
730 by the definitions based on the STEIT table 770 for air the scalable 
template items, then he/she click with the pointing device 105 on the "Yes to 
/A/r push-button 2629 and control is given to step 2552; 

• if he/she wants to replace the existing definition based on the STMT table 730 
by the definition based on the STEIT table 770 for the current scalable 
template item, then he/she click with the pointing device 105 on the "Ve^ 
push-button 2630 and control is given to step 2550; 

• if he/she does not want to replace the existing definition based on the STMT 
table 730 by the definition based on the STEIT table 770 for the cun-ent 
scalable template item, then he/she click with the pointing device 105 on the 
"N<f push-button 2628 and control is given to step 2553. 

In all the three cases, the frame 2631 and the objects it contains are no longer 
displayed on the display device 106 as soon as the spreadsheet user clicks with 
the pointing device 105 on one of the three push-buttons 2628, 2629. and 2630. 

At step 2552, the local variable STIM_replace_all is set equal to the value "yes" 
and then control is given to step 2550. 
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• At Step 2553, a test is perfonmed to check If the value of the local variable 
STIMJndexl Is greater than or equal to the value of the local variable 
STlM^STEIT^size. If it Is the case, then control is given to step 2536; othenwise 
control is given to step 2554. 

5 • At step 2554, the local variable STIMJndexl is initialised to the value 1 (one) 
and then control is given to step 2541 . 

• At step 2555, a test is performed to check if the value of the "referenced" 
attribute 740 of the "Type" field 737 of the STIM^STMT^rec record 731 is equal 
to ''template" or to "instance". If it is the case, then control is given to step 2556; 

10 otherwise control is given to step 2547. 

• At step 2556, a test is performed to check if the value of the "nature" attribute 
741 of the "Type^ field 737 of the STIM_STMT_rec record 731 is equal to 
"template". If it is the case, then control is given to step 2558; othenwise control is 
given to step 2557. 

15 • At step 2557, a test is performed to check if the respective values of the "meta" 
attribute 739 of the "Type^' field 737 of the STIM^STMT^rec record 731, of the 
"nature" attribute 741 of the "Typef' field 737 of the STIM_STMT_^rec record 731 , 
and of the "/nfo Field field 736 of the STIM_STMT_rec record 731, are equal 
to the values of the "meta" attribute 779 of the "Type^' fiejd 777 of the 
; 20 STIM_STEIT_rec record 771, of the "nature" attribute 771 of the/^typ^' field 777 
of the STIM_STEIT__rec record 771, and of the "Info Field 2" field 776 of the 
STIM_STEIT_rep record 771. If it is the case, then control is given to step 2547; 
othenwise control is given to step 2558. 

• At step 2558, a warning message notification is issued for Informing the user that 
25 the cunrently processed scalable template object cannot be imported (replacing 

the scalable template object currently defined under the same nanie), due to the 
risk of conupting the existing scalable template instances which abide by the 
definition of this scalable template object, upon any future update of those 
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scalable template instances. This can typically be done by displaying on the 
. display device 106 a warning message in a pop-up window, or in a status bar 
area, but any other similar means could be used instejad. without departing from 
the spirit of the invention. Once the user has acknowledged this notification 
5 message through conventional means such as clicking with the pointing device 
105 on an "OK" push-button present within a warning message pop-up window, 
or any other similar means without departing from the spirit of the invention, 
control is given to step 2553. 



El 4. Scalable Template Instance Export Manager method 

10 the method for exporting the variable part of an existing scalable template instance 
* from a source spreadsheet file to a destination spreadsheet instance export-import 
file used in a prefen-ed embodiment of the present invention is summarised in 
flowchart 2800 of FIG 28A. This method can be seen as the processing of the 
Scalable Template Instance Export Manager command. 

15 • At step 2801 , the method is in its default state, waiting for an event to initiate the 
process. 

• At step 2802, the Scalable Template Instance Export Manager command is 
detected, as a result of a user action. This action can be for instance a specific 
combination of key on the keyboard 104, or the click of the pointing device 105 

20 on a specific button, or any other similar means not further specified here. 

When the Scalable Template Instance Export Manager command is detected, 
the current spreadsheet selection corresponds to a range of cells, possibly 
reduced to a single individual cell, which is known as the currently selected range 
of cells and which comprises the currently selected cell. If this currently selected 

25 cell is not the top left cell within the currently selected range of cells, then the top 
left cell of the currently selected range of cells becomes the currently selected 
cell. . 
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• At Step 2803, a test is performed to check if the currently selected cell belongs to 
an existing scalable template instance. This test is perfonned by parsing the 
STIT table 750 and visiting in each record 751 the ''Address field 752 to 
detennine if the range of cells address specified in this field does include the 

5 address of the individual currently selected cell. If it is the case, then the cun-ently 
selected cell is contained in a scalable template instance and control is given to 
step 2804; othenA^ise control is given to the step 2836. 

• At step 2804, several local variables are initialised. 

• The local variable STIEM_name is initialised with the name of the range of 
10 cells corresponding to the scalable template instance to which the cun-ently 

selected cell belongs. If this scalable template instance is not a named range 
of cells, then the local variable STIEM^name defaults to an. empty character 
string. 

• Then the local variable STIEM_ST \s initialised with the value of. the "Sr field / . 
15 753 of the record 751 found at step 2803. 

• Then the local variable STIEM^body is; initialised with the value .oif the • 
"Element field 754 of the record 751 found at step 2803. 

• Then the local variable STIEM^header is initialised with the value oif the. 
"Header Sizd' field 756 of the record 751 found at step 2803. . 

20 • Then the local variable STIEMJooter is initialised with the value of the ''Footer ^ 
Siz^ field 757 of the record 751 found at step 2803. 

• Then the local variable STIEM_row is initialised with the value i (one). . 

• Then the local variable STIEMJIe is initialised with the default value 
corresponding to an empty character string, 

25 • Then the local variable STIEM__STLcell is initialised as being the top left cell of 
the scalable template instance to which the currently selected cell belongs. 

• Then the local variable STIEM__STDT_rec is initialised as being the top pair 
761 of the STDT table 760 pointed by the ""Description Ptf field 724 of the 
record 721 of the STT table 720 whose "A/ame^' field 722 is equal to the "Sr 

30 field 753 of the record 751 found at step 2803. 

• Then the local variable STIEM_STDT_name is initialised with the name of the 
element profile or meta-element profile within the pair STIEM_STDT_rec. 
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• Then the local variable STIEM^profile^desc is initialised as being the 
descriptive range of cells pointed by the ''Description Ptf field 714 of the 
record 711 of the EPT table 710, whose "NameT field 712 is equal to the local 
variable STIEM_STDT_name. 

5 • Then the local variable STIEMjcolmax is initialised with the value of the 
""Column r field 716 of the record 711 of the EPT table 710, whose "A/ame^ 
field 712 is equal to the local variable STIEM^STDT_name, 

• At step 2805, the Scalable Template Instance Export Manager Dialog Box 2700 
is displayed on the display device 106. At this stage of the Scalable Template 

10 Instance Export Manager method, the Scalable Template Instance Export 
Manager Dialog Box 2700 contains only three text boxes and four push-buttons: 

• the "Export fild' text box 2703 which is filled with the value of the local variable 
STIEMJile; 

• the "Instance NameT text box 2704 which is filled with the value of the local 
15 variable STIEM_name\ 

• the ''Template Name?" text box 2705 which is filled with the value of the local 
variable Sr/EM_Sr; 

• the push-button "A/a/T7eor/?enametf?e/nsfance?' 2712; 

• the push-button "Export/n a A/£M^f//e" 2714; 

20 • the push-button "Export /n an EX/S7/A/G///e^' 2713; 

• and the push-button "Cancer 2702. 

The two push-buttons ''Export in a NEW 2714 and "Export in an EXISTING 
filef' 2713 are enabled if and only if the value of the local, variable STIEM_name 
differs from the default value (empty character string). Othenwise these two 
25 push-buttons are disabled, so that any click with the pointing device 105 on them 
will not be recognised as a valid event. 

• At step 2806, the method is waiting for any user action on the Scalable Template 
Instance Export Manager Dialog Box 2700. Such user action is typically resulting 
from a click with the pointing device 105, but take other similar fomis such as, 

30 but not limited to a specific combination of key on the keyboard 104, or any other 
similar means not further specified here. 



wo 03/014987 



PCT/EP02/09483 



• At Step 2807, a user action on the Scalable Template Instance Export Manager 
Dialog Box 2700 Is detected. 

• If the user action is a click on the push-button "Export in a NEW fil^ 2714, 
then control is given to step 2810; 

5 • if the user action is a click on the push-button "Export in an EXISTING fil^ 
2713, then control Is given to step 2811; 

• if the user action is a click on the push-button ''Name or Rename the Instance 
2712, then control is given to step 2808; 

• if the user action is a click on the push-button "CanceP 2702, or on the 
. 10 closing-window push-button 2701 , then control Is given to step 2809. 

At step 2808, conventional means are used to interface with the spreadsheet 
user for naming the range of cells corresponding to the scalable template 
instance to which the currently selected cell belongs. In a preferred embodiment 
of the present invention, these means correspond to a conventional range name 
dialog, box displayed on the display device 106, but any other similar 
conventional means could be used Instead without departing from the spirit of the 
invention. Once the spreadsheet user has specified a new or an updated name 
for the range of cells corresponding to the scalable template Instance to which 
the currently selected cell belongs, the local variable STIEM^name is updated 
with this user specified name. Then control is given to step 2805. 

At step 2809, the Scalable Template Instance Export Manager Dialog Box 2700 
is closed and then control is given back to the initial step 2801 for processing any 
future Scalable Template Instance Export Manager command. 

At step 2810, conventional means are used to interface with the spreadsheet 
25 user for creating the new spreadsheet instance export-import file to be created. 
In a preferred embodiment of the present invention, these means con'espond to 
a conventional file creation dialog box displayed on the display device 106, but 
any other similar conventional means could be used instead without departing 
from the spirit of the invention. Furthemiore no specific assumption is made 
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regarding the file structure used in tlie environment where the spreadsheet 
application is running, as any conventional file stmcture can be used without 
influencing the spirit of the invention. Then control is given to step 2815. 

• At step 2811, conventional means are used to interface with the spreadsheet 
5 user for retrieving the existing spreadsheet instance export-import file to be 

updated. In a prefen^ed embodiment of the present invention, these means 
correspond to a conventional file selection dialog box displayed on the display 
device 106, but any other similar conventional means could be used instead 
without departing from the spirit of the invention. Furlhennore no specific 
10 assumption is made regarding the file staicture used in the environment where 
the spreadsheet application is running, as any conventional file structure can be 
used without influencing the spirit of the invention. 

• At step 2812, a test is perfomied to check if the file identified at step 2811 is a 
valid spreadsheet instance export-import file. This validity test corresponds to 

. 15 verifying that the spreadsheet file follows the logical file stmcture 275.0 illustrated 
by the FIG 27D, which is made of three parts. 

• The first part 2751 is the spreadsheet instance export-import file header 
containing a unique signature identifying a spreadsheet instance export-import 
file. 

20 • The second part 2752 is made of a table following the stmcture of a STJEIT 
table 790, as illustrated by FIG 7H. 

• The third and last part 2753 is the Descriptor area where are recorded the 
exported scalable template instances, stmctured as ESTIT tables 2740, 
pointed by the "Exported STI Ptf field 796 within the records 791 of the 

25 STIEIT-like table recorded within the second part 2752 of the spreadsheet 

instance export-import file. 
If the spreadsheet file follows this logical file stmcture 2750, then control is given 
to step 2814; othenwise control is given to step 2813. 

• At step 2813, a warning message notification is issued for infomiing the user that 
30 the selected file does not comply with the structure of spreadsheet instance 
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export-import files. This can typically be done by displaying on the display device 
106 a warning message in a pop-up window, or in a status bar area, but any 
other similar means could be used instead, without departing from the spirit of 
the Invention. Once the user has acknowledged this notification message 
S through conventional means such as clicking with the pointing device 105 on an 
"OK" push-button present within a waming message pop-up window, or any other 
similar means without departing from the spirit of the Invention, control is given to 
step 2805. 

• At step 2814, the second and third parts 2752 and 2753 of the selected file are 
10 loaded into memory to constitute the STIEIT table 790 and the associated 

exported scalable template instances in the form of ESTIT tables 2740. Then the 
local variable STIEMJile is initialised to the name of the spreadsheet instance 
export-import file retrieved from the spreadsheet user at step 2811. Then control . 
is given to step 2816. 

15 • At step 2815, an empty STIEIT table 790 is created in memory as well as the 
associated memory space for recording the exported scalable template instances 
in the fonn of ESTIT tables. Then the local variable STIEMJile is initialised to the 
name of the spreadsheet instance export-import file retrieved from the 
spreadsheet user at step 2810. 

20 • At step 2816, the Scalable Template Instance Export Manager Dialog Box 2700 
is refreshed on the display device 106, as the text box 2703 is filled with the 
updated value of the local variable STIEMJile, and as the progression bar 2706 
is displayed to reflect the fact that the currently processed row of the scalable 
template instance to which belongs the currently selected cell is the one of rank 

25 STIEM^row out of a set of size STIEMJeader -f STIEM^body + STIEMJooter. 

• At step 2817, within the STIEIT table 790, the first record 791 becomes the 
current record STIEM_STIEIT_rec^B^ of the STIEIT table 790. 
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At Step 2818, a test is performed on the STIEM^STIEIT^rec record. 791 to 
determine If the value of the "A/ame^ field 792 is equal to the value of the local 
variable STIEM^name. If it is the case, then control is given to step 2820; 
otherwise control is given to step 2819. 

At step 2819, a test is performed to check if the STIEM_STIEIT_rec record 791 is 
the last record of the STIEIT table 790. If it is the case, then control is given to 
step 2822; othenwise control is given to step 2821 . 

At step 2820, the Scalable Template Instance Export Manager Dialog Box'2700 
is updated by displaying in a frame 2711 some information related to a conflict 
between the record STIEM_STIEIT_rec 791 corresponding to an exported 
scalable template instance already existing in the spreadsheet instance 
export-import file and the record 791 to be built In the STIEIT table 790 for 
representing the exported scalable template instance derived from the scalable 
template , instance to . which the currently selected cell belongs. Both records 
correspond to the same scalable template instance name which is displayed in 
the text box 2704. The already existing STIEM_STIEIT_rec record 791 is time 
stamped with the date displayed in the text box 2707, and derived from a file 
whose name is displayed in the text box 2708. Being aware of these pieces of 
information, the spreadsheet user pan take a decision: 
if he/she wants to replace the existing exported scalable template instance 
based on the STIEIT table 790 by a new one derived from the current 
sjDreadsheet file, then he/she clicks with the pointing device 105 on the "Ve^' 
push-button 2710 and control is given to step 2823; 

if he/she does not want to replace the existing exported scalable template 
instance based on the STIEIT table 790 by a new one derived from the current 
spreadsheet file, then he/she clicks with the pointing device 105 on the "A/o" 
push-button 2709 and control is given to step 2809. 
In both cases, the frame 2711 and the objects it contains are no longer displayed 
on the display device 106 as soon as the spreadsheet user clicks with the 
pointing device 105 on one of the two push-buttons 2709, and 2710. 
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• At Step 2821, within the STIEIT table 790, the record 791 which follows the 
record STIEM_STIEIT_rec 791 becomes the new cun'ent record 
STIEM^STIEIT^rec 791 of the STIEIT table 790. 

• At step 2822, a new record 791 Is created In the STIEIT table 790. This new 
5 record becomes the record STIEM_STIEIT_rec 791 and is initialised as follows: 

• the "/Vame" field 792 is filled with the value of the local variable STIEM^name] 

• the ''Source File Nam^ field 793 is filled, with the name of the current 
spreadsheet file which can be retrieved by convehtipnal means from the 
spreadsheet environment system infomnation repository; 

10 • the "Export Datd' field 794 is filled with the current date and time which can be 
retrieved by conventional means from the spreadsheet environment system 
infonnation repository; 

• the ''Row #' field 795 is filled with the sum of the values of the three local 
variables STIEM^header, STIEM^body and STlEMJooter, 

15 • the "Exported STI Ptf field 796 is filled with the memory address of the. 

allocated memory space where the ESTIT. table 2740 will record the exported 

scalable template instance. 
Then the local variable STIEM^ESTIjcell is initialised as being the top. left cell of 
the ESTIT table 2740. Then control is given to step 2824. 

20 • At step 2823, the record STIEM_STIEIT_rec 791 is updated in the STIEIT table 
790. The "Source File Namd' field 793 is filled with the name of the cun^ent 
spreadsheet file which can be retrieved by conventional means from the 
spreadsheet environment system infonnation repository; the "Export Dat^ field 
794 Is filled with the current date and time which can be retrieved by conventional 

25 means from the spreadsheet environment system information repository; the 
"Row #" field 795 is filled with the sum of the values of the three local variables 
STIEM^headen STIEM_body and STIEMJooter, Then the local variable 
STIEM_ESTLcell is initialised as being the top left cell of the ESTIT table 2740. 

• At step 2824, some local variables are initialised: the local variable STIEM_col is 
30 initialised to the value 1 (one); the local variable STIEM^exportjcol is initialised 
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to the value 1 (one); the local variable STlEM^profilejoell is Initialised as being 
the leftmost cell within the range of ceils STIEMjprofile_desc, 

• At step 2825, a test is performed to checl< if STlEMjprofile^cell has been defined 
as an "IN" cell. If it is the case, then control is given to step 2826; othenA^ise 

S control is given to step 2827. 

• At step 2826, a conventional copy-paste operation by value is performed from 
. the individual cell STIEM^STLcell onto the individual cell STIEM_ESTLcell, 

Then the individual cell located immediately at the right of STIEM_ESTI_cell 
becomes the new cell STIEM_ESTLcelL Then the local variable 
10 STIEM^export_col is incremented by 1 (one). 

• At step 2827, the individual cell located immediately at the right of. 
STIEM^STLcell becomes the new cell STIEM^STLcell. The individual cell 
located immediately at the right of STIEM _profile_cell becomes the new cell 
STIEMjprofile_celL Then the local variable STIEM^col Is incremented by 1 

15 (one). 

• At step 2828, a test is perfomied to determine if the value of the local variable 
STIEM^col is greater than the value of the local variable STIEM^colmax. If it is 
the case, then control is given to step 2829; othenA^ise control is given to step 
2825. 

20 • At step 2829, the individual cell located on the left of STIEM_ESTI_cell by a 
number of columns equal to the value of the local variable STIEM_export_col 
• becomes the new cell STIEM_ESTLcelL Then the individual cell 
STIEM_ESTLcell is filled with the value of the local variable STIEM_export_coL 
Then the individual cell located immediately at the right of STIEM^ESTLcell 

25 becomes the new cell STIEM_ESTLcell. 

• At step 2830, a test is perfomned to detemiine if the value of the local variable 
STIEM_row is greater than or equal to the sum of the values of the three local 
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variables STlEM_header, STIEM_body, STIEMJooter. If it Is the case, then 
control Is given to step 2835; othenA/lse control Is given to step 2831. 

At step 2831, the individual cell located on the left of STIEM_STI_cell by a 
number of columns equal to the value of the local variable STIEM_col 
decremented by 1 (one) becomes the new cell STIEM_STLcell. Then the 
individual cell located immediately below ST/EM_S7Lce// becomes the new cell 
.STIEM_STLcell. Then the individual cell located immediately below 
Sr/E/VLESr/_ce// becomes the new cell STIEMJESTI_cell. 

At step 2832, a test is perfomied to determine if the value of the local variable 
STIEM_row is less than or equal to the. value pf the local variable 
STIEM_header. If it is the case, then control is given to step 2834; othenwise 
control is given to step 2833. 

At step 2833, a test is perfomied to detennine if the value of the iocal variable 
STIEM_row is greater than or equal to the sum of the values of ttie two local 
variables STIEMJieader, STIEM_body. If it is the case, then control is given to 
step 2834; othenArise control is given to step 2837. 

At step 2834, in the STDT table 760, the pair which follows , the 
STIEM_STDT_rec pair becomes the new pair STIEM_STDT_rec. Then the local 
variable STIEM_STDT_name is initialised with the name of the element profile or 
meta-element profile wittiin the pair STIEM_STDT_rec. Then the local variable 
STIEM_profile_desc is initialised as being the descriptive range of cells pointed 
by the "D^scnpf/on Pti^ field 714 of the record 711 of the EPT table 710, whose 
"Nam^' field 712 is equal to the local variable STIEM_STDT_name. Then control 
is given to step 2837. 

At step 2835, the STIEIT table 790 and the associated exported scalable 
template instances recorded in ESTIT tables 2740 are saved on the cun-ent 
spreadsheet instance export-import file to respectively constitute the updated 
second part (STIEIT-like table) 2752 and the updated third part (Descriptor Area) 
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2753 of the logical structure 2750 followed by the spreadsheet instance 
export-import file. Then control is given to step 2809. 

• At step 2836, a warning message notification is issued for infomiing the user that 
the scalable template instance export operation can only be performed if the 
5 curently selected cell is located within an existing scalable template instance. 
This can typically be done by displaying on the display device 106 a warning 
message in. a pop-up window, or in a status bar area, but any other similar 
means could be used instead, without departing from the spirit of the invention. 
Once the user has acknowledged this notification message through conventional 
10 means such as clicking with the pointing device 105 on an "OK" push-button 
present within a waming message pop-up window, or any other similar means 
without departing from the spirit of the invention, control is given to the initial step 
2801 for processing any future Scalable Template Instance Export Manager 
cbmmand. . 

15 • At step 2837, the local variable STIEM^row is incremented by 1 (one). Then the 
Scalable Template Instance Export Manager Dialog Box 2700 is refreshed on the 
display device 106, as the progression bar 2706 is displayed to reflect the fact 
that the currently processed row of the scalable template instance to which 
belongs the currently selected cell is the one of rank STIEM^row out of a set of 

20 size STIEM^header + STIEM_bocly + STIEMJooter. Then control is given to 
step 2824. 

El 5. Scalable Template Instance Import Manager method 

The method for importing the variable part of an existing scalable ternplate instance 
from a source spreadsheet file to a destination spreadsheet instance export-import 
25 file used in a preferred embodiment of the present invention is summarised in 
flowchart 2840 of FIG 28B. This method can be seen as the processing of the 
Scalable Template Instance Import Manager command. 
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• At Step 2841 , the method is in its default state, waiting for an event to initiate the 
process. 

• At step 2842, the Scalable Template Instance Import Manager command is 
detected, as a result of a user action. This action can be for instance a specific 

5 combination of key on the keyboard 104, or the click of the pointing device 105 
on a specific button, or any other similar means not further specified here. 
When the Scalable Template Instance Import Manager command is detected, 
the current spreadsheet selection corresponds to a range of cells, possibly 
reduced to a single individual cell, which is known as the currently selected range 

10 of cells and which comprises the currently selected cell. If this cun^ently selected 
cell is not the top left cell within the cun-entiy selected range of cells, then the top 
. left cell of the currently selected range of cells becomes the currently selected 
cell. 

• At step 2843, a test is performed to check if the currently selected cell belongs to 
15 an existing scalable template instance, this test is perfbnned by parsing the . 

STIT table 750 and visiting in each record 751 the Mdc/ress" field 752 to 
detemfiine if the range of cells address specified in this field does include the. 
address of the individual currently selected cell. If it is the case, then the cun-ently 
selected cell is contained in a scalable template instance and control is given to 
20 step 2844; othenA^ise control is given to step 2873. 

• At step 2844, several local variables are initialised. 

• The/local variable STIIM^name is initialised with the name of the range of ceils 
con-esponding to the scalable template instance to which the. cun^ently 

. selected cell belongs. If this scalable template instance is not a nameid range 
25 of cells, then the local variable STIIM^name defaults to an empty character 
string. 

• Then the local variable STIIM^ST is initialised with the value of the "Sr field 
753 of the record 751 found at step 2843. 

• Then the local variable STIIM^body is initialised with the value of the "Element 
30 field 754 of the record 751 found at step 2843. 
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Then the local variable STIIM_header is Initialised with the value of the 
"Header Sizd" field 756 of the record 751 found at step 2843. 
Then the local vari^le STIIM_footer is initialised with the value of the "Footer 
Sizd' field 757 of the record 751 found at step 2843. 
Then the local variable STIIM_mw is initialised with the value 1 (one). 
Then the locsal variable STIIM_file is initialised with the default value 
corresponding to an empty character string: 

Then the local variable STIIM_STI_cell\s initialised as being the top left cell of 
the scalable template instance to which the currently selected cell belongs. 
Then the local variable STIIM_STDT_rec \s initialised as being the top pair 761 
of the STDT table 760 pointed by the "Description Ptf field 724 of the record 
721 of the STT table 720 whose "Nam^ field 722 is equal to. the "ST field 753 
of the record 751 found at step 2843. 

Then the local variable STIIM_STDT_name is initialised with the name of the 
element profile or meta-element profile within the pair STIIM_STDZlrec. 
Then the local variable STIIM_profile_desc is initialised as being the 
descriptive range of cells pointed by the "Description Pf/". field 714 of the 
record 711 of the EPT table 710, whose "NameT field 712 is equal to the local 
variable ST//iW_SrDr_na/77e. 

Then the local variable STllMjcoimax is initialised with the value of the 
"Column #■ field 716 of the record 711 of the EPT table 710, whose "/Vam^' 
field 712 is equal to the local variable STIIM_STDT_name. 

At step 2845, the Scalable Template Instance Import Manager Dialog Box 2720 
is displayed on the display device 106. At this stage of the iScalabie Template 
Instance Import Manager method, the Scalable Template Instance Import 
Manager Dialog Box 2720 comprises only three text boxes and three 
push-buttons: 

the "Import fiid' text box 2723 which is filled with the value of the local variable 
STHM_m 

the "Instance Nam^ text box 2724 which is filled with, the value of the local 
variable STIIM_name; 
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• the "Template Namd" text box 2725 which is filled with the value of the local 
variable STIIM_ST\ 

• the push-button "Name or Rename the Instance 2727; 

• the push-button "Select an Import Fil^ 2728; 

• the push-button 'Cancer 2722. 

The push-button "Select an Import Fil^ 2728 is enabled if and only if the value of 
the local variable STIIM_name differs from the default value (empty character 
string). Othenwise this push-button Is disabled; so that any click with the pointing 
deyice 1 05 on it will not be recognised as a valid event. 

At step 2846, the method is waiting for any user action on the Scalable Template 
Instance Import Manager Dialog Box 2720. Such user action is typically resulting 
from a click with the pointing device 105, but take other similar forms such as, 
but not limited to a specific combination of key on. the keyboard, 104, or any other 
similar means not further specified here. 

At step 2847, a user action on the Scalable Template Instance Import Manager 
Dialog Box 2720 is detected. If the user actipn is a click on the push-button 
"Select an Import FM 2728, then control is given to step 2850. If the user action 
is. a click on the push-button "Name or Rename the Instance 2727, then control 
is given to step 2848. If the user act|on is a click on the push-button "Cancer 
2722, or on the closing-window push-button 2721, then control is given to step 
2849. 

At. step 2848, conventional means are used to interface with the spreadsheet 
user for naming the range of cells con-esponding to the scalable template 
instance to which the currently selected cell belongs. In a prefen-ed embodiment 
of the present invention, these means correspond to a conventional range name 
dialog box displayed ori the display device 106, but any other similar 
conventional means could be used instead without departing from the spirit of the 
invention. Once the spreadsheet user has specified a new or an updated name 
for the range of cells conresponding to the scalable template instance to which 
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the currently selected cell belongs, the local variable STIIM_name is updated 
with this user specified name. Then control is given to step 2845. 

• At step 2849, the Scalable Template Instance import Manager Dialog Box 2720 
is closed and then control is given back to the initial step 2841 for processing any 

is future Scalable Template Instance Import Manager command. 

• At step 2850, conventional means are used to interface with the spreadsheet 
user for retrieving the existing spreadsheet instance export-import file to be 
accessed. In a preferred embodiment of the present invention, these means 
correspond to a conventional file selection dialog box displayed on the display 

10 device 106, but any other similar conventional means could be used instead 
without departing from the spirit of the invention. Furthermore no specific 
assumption is made regarding the file stmcture used in the environment where 
. the spreadsheet application is running, as any conventional file structure can be 
used without influencing the spirit of the invention. . 

15 • At step 2851, a test is peri^omied to check if the file Identified at step 2850 is a 
valid spreadsheet instance export-import file. This validity test con-esponds to 
verifying that the spreadsheet file follows the logical file stmcture 2750 illustrated 
by the FIG 27D, which is made of three parts. 

• The first part 2751 is the spreadsheet instance export-import file header 
20 containing a unique signature identifying a spreadsheet instance export-import 

file. 

• The second part 2752 is made of a table following the structure of a STIEIT 
table 790, as illustrated by FIG 7H. 

• The third and last part 2753 is the Descriptor area where are recorded the 
25 exported scalable template instances, structured as ESTIT tables 2740, 

pointed by the ""Exported STI Ptf fields 796 within the records 791 of the 
STIEIT-like table recorded within the second part 2752 of the spreadsheet 
instance export-import file. 
If the spreadsheet file follows this logical file structure 2750, then control is given 
30 to step 2853; othenA^ise control is given to step 2852. 
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• At Step 2852, a warning message notification is issued for informing the user that 
the selected file does not comply with the structure of spreadsheet instance 
export-import files, this can typically be done by displaying on the display device 
106 a warning message in a pop-up window, or in a status bar area, but any 

S other similar means could be used instead, without departing from the spirit of 
the invention. . Once the user has acknowledged this notification message 
through conventional means such as clicking with the pointing device 105 on an 
"OK" push-button present within a warning message pop-up window, or any other 
similar means without departing from the spirit of the invention, control is given to 
10 step 2845. 

• At step 2853, the second and third parts 2752 and 2753 of the selected file are 
loaded into memory to constitute the STIEIT table 790 and the associated 
exported scalable template instances in the fonri of ESTIT tables 2740. Then the 
local variable STIIM_file is initialised to the name of the spreadsheet instance 

15 . export-import file retrieved from the spreadsheet user at step 2850. ; . 

• At step 2854, the Scalable Template Instance Import Manager Dialog Box 2720 
is refreshed on the display device 106, as the text box 2723 is filled with the 
updated value of the local variable STIIMJile, and as the progression bar 2726 is 
displayed to reflect the fact that the currently processed row of the scalable 

20 template instance to which belongs the currently selected cell is the one of rank 
STIIM_row out of a set of size SJUM^header + STIIM_body + STIIMJooter. 

• At step 2855, within the STIEIT table 790, the first record 791 becomes the 
current record STIIM^STIEIT^rec 791 of the STIEIT table 790. 

• At step 2856. a test is perfomfied on the STIIM^STIEIT^rec record 791 to 
25 determine if the value of the "Nam^ field 792 is equal to the value of the local 

variable STIIM^name. li it is the case, then control is given to step 2872; 
othenA/ise control is given to step 2857. 
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• At Step 2857, a test is performed to check if tlie STIIM_STIEIT_rec record 791 is 
the last record of the STIEIT table 790. If it is the case, then control is given to 

. step 2858; otherwise control is given to step 2859. 

• At step 2858, a warning message notification is issued for infonning the user that 
5 the selected file does not comprise any exported scalable template instance that 

shares the same name as the scalable template instance to which the cun^ently 
selected cell belongs. This can typically be done by displaying on the display 
device 106 a warning message in a pop-up window, or in a status bar area, but 
any other similar means could be used instead, without departing from the spirit 
10 of the invention. Once the user has acl<nowledged this notification message 
through conventional means such as clicking with the pointing device 105 on an 
"OK" push-button present within a warning rhessage pop-up window, or any other 
similar means without departing from the spirit of the invention, control is given to 
step 2845- 

15 • At step 2859, within the STIEIT table 790, the record 791 which follows the 
recbrd STIIM_STIElT_rec 791 becomes the new current record 
STIIM^STIEIT^rec 791 of the STIEIT table 790. 

• At step 2860, some local variables are initialised: 

• the local variable STIIM^col is initialised to the value 1 (one); 

20 • jthe local variable STIIM_export_col\B initialised to the value 1 (one); 

• the local variable STIIM_profile_cell is initialised as being the leftmost cell 
within the range of cells STIIM_profile_desc] 

• the local variable STIIM_export_coLmax is initialised with the content of the 
individual cell STIIM__ESTLceli: 

25 Then the individual cell located immediately at the right of STIIM^ESTLcell 
becomes the new cell STIIM^ESTLcelL 

• At step 2861 , a test is perfomied to check if STIIMjprofile^cell has been defined 
as an "IN" cell. If it is the case, then control Is given to step 2862; othenvise 
control is given to step 2863. 
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At Step 2862, a conventional copy-paste operation by value is perfonned from 
tlie Individual cell STIIM^ESTLcell onto the individual cell STIIM^STLcelL Then 
the Individual cell located immediately at the right of STIIM^ESTLcell becomes 
the new cell STIIM^ESTLcelL Then the local variable STIIM_export_col is 
incremented by 1. (one). 

At step 2863, the individual cell located immediately at the right of 
Sr//M_STLce// becomes the new cell STIIM^StLcelL The individual cell located 
immediately at the right of STIIM_profile_cell becomes the new cell 
\STIIMjprofile_cell Then the local variable Sr//M_co/ is incremented by 1 (one). 

At step 2864, a test is perfonned to detemiine if the value of the local variable 
STIIM_col is greater than the value of the local variable STIIM^colmax. If it is the 
case, then control is given to step 2866; othenA^lse control is given to step 2865. 

At step 2865, a test is perfonned to detennine if the value of the local variable 
STIIM_export_col is greater than the value of the . .local variable 
STIlM^exportjcoLmax, If it is the case, then control is given to step 2866; 
othenwise control is given to step 2861 . 

At step 2866, a test is perfonned to detennine if the value of the local variable 
SfllM_row is greater than or equal to the sum of the values of the three local 
variables STIIM^header, STIIM^body, STIIMJpoter, or if the value of the local 
variable STIIM_row \B greater than or equal to the value of the local variable 
STIIM_row_max. If it is the case, then control is given to step 2849; othenA/ise 
control is given to step 2867. 

At step 2867, the individual cell located on the left of STIIM^STLcell by a 
number of columns equal to the value of the local variable STIIM^col 
decremented by 1 (one) becomes the new cell STIIM^STLcelL Then the 
individual cell located immediately below STIIM^STLcell becomes the new cell 
STIIM^STLcell. Then the individual cell located on the left of STIIM^ESTLcell 
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by a number of columns equal to the value of the local variable 
STIIM_export_cell becomes the new cell StllMJESTLcell. Then the individual 
cell located immediately below STIIM_ESTI_cell becomes the new cell 
STIIM_ESTLcell. 

At step 2868, a test is perfomied to detemiine if the value of the local variable 
STIIM_row is less than or equal to the value of the local variable STIIM_header. 
If it is the case, then control is given to step 2870; otherwise control is given to 
step 2869. 

At step 2869, a test is performed to determine If the value of the local variable 
STIIM_row is greater than or equal to the sum of the values of the two local 
variables STHM_header, STIIM_body. If it is the case, then control is given to 
step 2870; othenwise control is given to step 2871 . 

At step 2870, in the STDT table 760, the pair which follows the. STIIM_STDT_rec 
pair becomes the new pair STIIM_STDT_rec. Theh the local variable 
STIIM_STDT_name is initialised with the name of the element profile or 
meta-element profile within the pair STIIM_STDT_rec. Then the local variable 
STIIMjf)rofile_desc is initialised as being the descriptive range of cells pointed by 
the 'Description Ptf field 714 of the record 711 of the EPT table 710, whose 
"Nam^ field 712 is equal to the local variable STllM_STDT_name. 

At step 2871, the local variable STIIM_row is incremented by 1 (one). Then the 
Scalable Template Instance Import Manager Dialog Box 2720 is refreshed on the 
display device 106, as the progression bar 2726 is displayed to reflect the fact 
that the cun-ently processed row of the scalable template instance to which 
belongs the cun-ently selected cell is the one of rank STIlM_row out of a set of 
size STIIMJieader + STHM_body + STIlMJooter. Then control is given to step 
2860. 

At step 2872, the local variable STIIM_row_max is initialised to the value of the 
"Row #• field 795 of the STIIM_STIEIT_rec record 791 identified at step 2856. 
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Then the local variable STIIM_ESTLcell is inrtialised as being the leftmost cell 
2742 of the top record 2741 of the ESTIT table 2740 pointed by the ""Exported 
STI Ptf field 796 of the STIlM^STlEIT^rec record 791 identified at step 2856. 
Then control is given to step 2860. 

5 • At step 2873, a warning message notification is issued for infonning the user that 
the scalable template instance import operation can only be performed if the 
currently selected cell is located within an existing scalable template instance. 
This can. typically be done by displaying on the display device 106 a waming 
message in a pop-up window, or in a status bar area, but any other similar 

10 means could be used instead, without departing from the spirit of the invention. 
Once the user has acknowledgeid this notification message through conventional 
means such as clicking with the pointing device 105 on an "OK" push-button 
present within a waming message pop-up window, or any other similar means 
without departing from the spirit of the invention,. control is given to the initial step 

15 2841 for processing any future Scalable Template instance Import Manager 
command. 

El 6. Scalable Template Instance Sort Application Manager method 

The method for perfonming a sorting application on a scalable template instance 
used in a preferred embodiment of the present invention can be summarised in 
20 flowchart 2900 of FIG 29A: This method can be seein as; the processing of the 
Scalable Template Instance Sort Application Mana^^ 

• At step 2901, the method is in its default state, waiting for an event to Initiate the 
process. 

• At step 2902, the Scalable Template Instance Sort Application Manager 

25 command is detected, as a result of a user action. This action can be for 
instance a specific combination of key on the keyboard 104, or the click of the 
pointing device 105 on a specific button, or any other similar means not further 
specified here. 
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When the Scalable Template Instance Sort Application Manager command is 
detected, the current spreadsheet selection corresponds to a range of cells, 
possibly reduced to a single Individual cell, which is known as the cun^ently 
selected range of cells and which comprises the cunrently selected cell. If this 
S currently selected cell is not the top left cell within the cunrently selected range of 
cells, then the top left cell of the currently selected range of cells becomes the 
currently selected cell. 

• At step 2903, a test is perfonmed to check if the cun-entiy selected range of cells 
(referred to as ST/S/WLrange) overlaps any existing scalable template instance. 

10 This test is perfomied by parsing the STIT table 750 and visiting in each record 
751 the "Address field 752 to determine if the range of cells address specified in 
this field does overlap the address of the currently selected range of cells 
STISM^range, If it is the case, then control is given to step 2904 ; othenA^ise 
control is given to step 2917. 

15 • At step 2904, a test is perfomned to check if the cunrently selected cell is located 
within any existing scalable template instance. This test is perfomned by parsing 
the STIT table 750 and visiting in each record 751 the ""Addresif field 752 to 
detennine if the range of cells address specified in this field does include the 
address of the individual cun-ently selected cell. If it is the case, then the cun^ntly 

20 selected cell is contained In a scalable template instance named 
STISMJnstahce_range and control is given to step 2905 ; othenwise control is 
given to step 2906. 

• At step 2905, two local variables STISM^element and STISMJnstance are 
initialised with the value "enable". Then the local variable STISM^mode takes the 

25 default value "element". Then control is given to step 2907. 

• At step 2906, two local variables STISM^element and STISMJnstance are 
initialised with the value "disable". Then the local variable STISM_mode takes the 
default value "range". 
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• At step 2907, if the local variable STISMJnstance is equal to "disable", then the 
. local variable STISM_name takes the value "none". If the local variable 
STISMJnstance is equal to "enable", then the local variable STISMjfiame takes 
the value of the name of the scalable template which is abided by the scalable 
5 template instance STISMJnstance_range. This name can be retrieved from the 
"Sr field 753 within the record 751 of the STit table 750. associated to the 
scalable template instance STISMJnstance^range. . 

. Then several tests are performed to evaluate the potential Impact of the sorting 
10 application according to the "range" mode, on any already existing scalable 
template Instance. These tests require to parse the STIT table 750, and to visit 
each record 751 to learn the address {"Addres^' field 752) and the importance 
{"Criticar field. 755) of every already defined scalable template instance. These 
tests evaluate either if two given ranges of cells partially overiap (meaning that 
15 . there exist, in the first range of cells at least one ceil belonging to the second 
. . range of cells and at least one cell not belonging to the second range oif cells) or 
if a first given range of cells is included within a second given range of cells 
(meaning that every cell belonging to the first range of cells belongs too to the 
second range of cells). Different conventional range comparisori techniques can 
20 be used for evaluating either range partial overiapping or range inclusion, without 
departing from the spirit of the present invention; they will not be described in the 
preferred embodiment of the present invention. 

If there exists at least one existing scalable template instance whose "Criticar 
25 field 755 takes the value 'Ves" and which partially or totally overlaps the currently 
selected range of cells STISM^range, then the local test variable 
STISM_range_critical takes the value "yes"; otherwise the local test variable 
Sr/Sfl/Lrangfe^cr/Y/ca/ takes the value "no". 

30 If there exists at least one existing scalable template instance whose "Cr/f/car 
field 755 takes the value "no" and which partially or totally overiaps the currently 
selected range of cells STISM^range, then the local test variable 
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STISM_mnge_other takes the value "yes"; otherwise the local test variable 
STISM_riange_othertakes the value "no". 

• At step 2908, the Scalable Template Instance Sort Manager Dialog Box 2920 Is 
displayed on the display device 106. The label box 2931 is initialised with the 
S name of the scalable template that the scalable template instance STISMjname 
abides by. If the local parameter STISM_element takes the value "enable", then 
the option button 2929 is enabled, meaning that any futur^ click on it with the 
pointing device 105 will be recognised as a valid event. If the local parameter 
STISM_element takes the value "disable", then the option button 2929 is 

10 disabled, meaning that any future click on It with the pointing device 105 will not 
be recognised as a valid event. If the local parameter STISMjnstance takes the 
value "enable", then the option button 2928 is enabled, meaning that any future 
click on It with the pointing device 105 will be recognised as a valid event. If the 
local parameter STISMjnstance takes the value "disable", then the option button 

15 2928 Is disabled, meaning that any future clfek on it with the poirttlhg device 105 
will not be recognised as a valid event. Then if the local variable STISM_mode 
takes the respective value "range", or "element", or "instance", then, the option 
button 2930, or 2929, or 2928 displays alone a black point. Then the text box 
2932 is Initialised with the value of the local variable STISM_rang9_cinical. Then 

20 the text box 2933 is Initialised with the value of the . local variable 
STISM_range_other. Then the text box 2925 is initialised with the value "yes" 
(respectively "no") if the local variable STISM_range_critical is equal to "no" 
(respectively "yes"). Then the text box 2926 is initialised with the value S-es" 
(respectively "no") if the local variable STISM_element takes the value "enable" 

25 (respectively "disable"). Then the text box 2927 is initialised with the value "yes" 
(respectively "no") if the local variable STISMjnstance takes the value "enable" 
(respectively "disable"). Finally the "Sorf push-button 2923 Is enabled if tlie text 
box 2925 shows the value "yes" and the option button 2930 shows a black point, 
or if the text box 2926 shows the value "YEs".and the option button 2929 shows a 

30 black point, or if the text box 2927 shows the value "yes" and the option button 
2928 shows a black point. 
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• At Step 2909, the method is waiting for any user action on the Scalable Template 
Instance Sort Manager Dialog Box 2920. Such user action is typically resulting 
from a click with the pointing device 105, but take other similar fomris such as, 
but not limited to a specific combination of key on the keyboard 104, or any other 

S similar means not further specified here. 

• At step 2910, a user action on the Scalable Template Instance Sort Manager 
Dialog Box 2920 is detected. 

• If the user action is a click on the "Sorf push-button 2923, then control is given 
to step 2913; 

10 • if the user action is a click on one of the option buttons 2930, or 2929, or 2928, 
then control is given to step 291 1 ; 

• if the user action is a click on the ""Cancer push-button 2922, or on the 
closing-window push-button 2921 , then control is given to step 2912.. 

. • At step 2911, the local variable STISM_mode takes the value "range", or 
15 "element", or "instance", if the spreadsheet user has respectively clicked with the 
pointing device 105 on the option button 2930, or 2929, or 2928. Then control is 
given to step 2908. 

• At step 2912, the Scalable Template Instance Sort Manager Dialog Box 2920 is 
closed (if it was opened) and then control is given back to the initial step 2901 for 

20 processing any future Scalable Template Instance Sort Applicatidh Manager 
command. 

• At step 2913, a test is performed to check the value of the local variable 
STISM^mode, If this local variable is found equal to "range", then control is given 
to step 2916; if it is found equal to "instance", then control is given to step 2915; if 

25 it is found equal to "element", then control is given to step 291 4. 

• At step 2914, the cunrently selected range of cells STISMjrange is reshaped so 
that it first occupies all the columns of the scalable template Instance 
STISMJnstance^range and second does not occupy any row outside the 
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intersection of the body part of the scalable template instance 
STISMJnstance^mnge with the previous position of the selected range of cells. 
Then the currently selected cell becomes the top left cell of this reshaped 
currently selected range of cells. Then control is given to step 2917. 

5 r At step 2915, the curently selected range of cells is reshaped so that It occupies 
the same rows and columns as the body part of the scalable template instance 
Sr/SMJ/7sfance_/ansfe. Then control is given to step 2917. 

• At step 2916, the STIT table 750 is scanned to remove from it any record 751 
. corresponding to a cormpted scalable template instance, as found at step 2907. 
10 Each time such a record 751 has been removed from the STIT table 750, the 

"Reference Housekeeping Process", as described in step 1414 of the Scalable 
Template Instanciator method, is invoked and executed before looking for any 
other record 751 to be removed from the STIT table 750. 

• At step 2917, the conventional user-interface means are used to retrieve from 
15 . the spreadsheet user the conventional options and parameters characterising the 

sorting application. Such means can typically correspond to the display of a 
dedicated dialog box on the display device 106, but any other similar means 
could be used instead without departing from the spirit of the present invention; 

. / At step 2918, the sorting , operation is perfomned according to the conventional 
20 means on the range of cells which may have been reshaped during previous 
steps 2914 or 2915. Then control is given to step 2912. 

ALTERNATE EMBODIMENTS 

The methods and systems according to the present invention may be used 
advantageously in those environments where elements of information are organised 
25 as vertically structured two dimensions tables. 
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The methods and systems according to the present invention may be used 
advantageously in those environments where elements of infomiation are organised 
as multidimensional tables having more than two dimensions. 

While the invention has been particularly shown and described with reference to a 
5 preferred embodiment, it will be understood that various changes in fomi and detail 
may be made therein without departing from the spirit, and scope of the invention. 
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Claims 

What is claimed is: 

1. A method for exporting-importing the content of input cells from a source scalable 
template instance in a source multi-dimensional spreadsheet to a destination 
5 scalable template instance in a destination muHi-dimensional spreadsheet; a 
multi-dimensional spreadsheet comprising a plurality of cells identified by a cell 
address along each dimension; a scalable template instance comprising a variable 
number of contiguous elements of same size ordered and aligned along a given 
spreadsheet dimension and structured according to information defined in an 

10 associated scalable template; an element being defined as a range of cells; a range 
of cells comprising one or a plurality of cells; said scalable template comprising an 
element profile; an element profile defining a cell content and a cell destination for 
each cell within each element; said cell destination specifying whether the cell is an 
input cell for receiving an entry or an output cell for producing a result; said method 

15 comprising the steps of: 

• Detecting a command for exporting-importing input cells from a source scalable 
template instance in a source spreadsheet to a destination scalable template 
instance in a destination spreadsheet; 

• Identifying the source scalable template associated with the source scalable 
20 template instance; 

• Identifying cells, if there are any, defined as input cells in the element profile of 
the source scalable template; 

• Identifying the destination scalable template associated with the destination 
scalable template instance; 

25 • Identifying cells, if there are any, defined as input cells In the element profile of 
the destination scalable template; 

• Copying cell per cell, the content of each input cell of the source scalable 
template instance in each input cell of the destination scalable template instance. 
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2. The method according to the preceding claim wherein the content of each input 
cell of the source scalable template instance is copied within each input cell of the 
destination scalable template instance input cell per input ceil starting with the first 
input cell of the first element of both source and destination scalable template 

5 instance. 

3. The method according to any one of the preceding claims wherein the source 
spreadsheet and the destination spreadsheet are the same spreadsheet. 

4. The method according to any one of the preceding claims wherein the step of 
copying cell per cell, the content of each input dell of the source scalable template 

10 instance in each input cell of the destination scalable template instance, comprises 
the further steps of: 

• Determining whether the number of elements in the source scalable template 
. instance is greater than the number of elements in the destination scalable 
template instance or not; 

15 If the number of elements in the source scalable template instance is greater 
than the number of elements in the destination scalable template instance: 

• Selecting in the source scalable template, a number of elements equal to the 
number of elements of the destination scalable template instance; 

• Copying cell per cell, the content of each input cell of each selected element 
20 of the source scalable template instance, in each input cell of each element of 

the destination scalable template instance. 

5. The method according to any one of the preceding claims wherein the istep of 
selecting in the source scalable template, a number of elements equal to the 
number of elements of the destination scalable template instance, comprises the 

25 step of: 



293 



wo 03/014987 



PCT/EP02/09483 



• selecting the elements In the source scalable template Instance by starting with 
the first element. 

6. The method according to any one of the preceding claims wherein the step of 
copying cell per cell, the content of each input cell of the source scalable template 

S instance in each input ceil of the destination scalable template instance, comprises 
the further steps of; 

• Detemnining whether the number of input cells in each element of the source 
scalable template instance is greater than the number of input cells in each 
element of the destination scalable template instance or not; 

10 If the number of input cells in each element of the source scalable template 
instance is greater than the number of input cells in each element of the 
destination scalable template instance: 

• Selecting in each element of the source scalable template, a number of input 
cells equal to the number of input cells in each element of the destination 

15 scalable template Instance; 

• Copying cell per cell, the content of each selected input cell of each element 
of the source scalable template instance, in each input cell of each element of 
the destination scalable template instance. 

7. The method according to any one of the preceding claims wherein the step of 
20 selecting in the source scalable template, a number of input cells in each element 

equal to the number of input cells in each element of the destination scalable 
template instance, comprises the step of: 

• selecting the input cells in each element of the source scalable template instance 
by starting with the first input cell in each element. 

25 8. The method according to any one of the preceding claims wherein the step of 
copying cell per cell, the content of each input cell of the source scalable template 
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instance in each input cell of the destination scalable template instance, comprises 
the further steps of: 

• Storing the content of input cells of the source scalable template in a temporary 
file. 

S 9. The method according to any one of the preceding claims wherein an element 
profile defines for each cell of an element: 

• A fomnula, said formula referring to one or a plurality of cells; or 

• A default value. 

10. The method according to any one of the previous claims wherein each element 
10 profile comprises: 

• a profile illustrative range of cells; 

• for each cell belonging to said profile illustrative range of cells,. a cell content and 
a cell destination. 

11. The method according to any one of the preceding claims wherein a scalable 
15 template further comprises an. element fomiat; an element fomiat defining for each 

cell within an element, one or a plurality of fomnat attributes. 

12. The method according to any one of the preceding claims wherein an eieiiient 
. format defines for each cell of an element one or a plurality of : 

• Background attributes; and/or 
20 • Alignment attributes; and/or 

• Font attributes; and/or 

• Line attributes; and/or 

• Protection attributes. 
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13. The method according to any one of the previous claims wherein each element 
format comprises: 

• a format illustrative range of cells; 
S • for each cell belonging to said fomiat illustrative range of cells, one or a plurality 
of format attributes. 

14. A system comprising means adaptisd for carrying out the steps of the method 
according to any one of the preceding claims. 

15. A computer program comprising instructions for carrying out the steps of the 
10 method according to any one of claims 1 to 13, when said computer program is 

executed. 
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ERR 


ERR 


ERR 


ERR 


< 
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Some fonnulas contained in the Cash Accounting Journal inustrated In FIG 11 A 


Cell 


Contents of cell 


F4 


+F3+D4-E4 


G4 


+G3+@IF(B4=''Sal8";D4:0) 


H4 


+H3+@IF(B4="ExpensB-:E4;0) 
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+i3+@iF(B4=^Purchase":E4:0) 


F5 


+F4+D5-E5 


G5 


+G4+@IF(B5="SaIe";D5:0) 


H5 


+H4+@IF(B5="Expense-:E5;0) 
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+l4+@IF(B5="Purchase":E5:0) 
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Cash Accounting Journal 


Date 


Type of 
Transaction 


Object of 
Transaction 


$ln 


$Out 


$ Balance 


Cumulative 
Sales 


Cumulative 
Expenses 


Cumulative 
Purchases 


01/05/01 


IniUal E 


lalance 






$50.00 


$0.00 


$0.00 


$0.00 


■o'27oS/bl 


Sale 


Book 


$20.00 




$70.00 


$20.00 


$0.00 


$0.00 


03/05/01 


Expense 


Telephone 




$15.00 


$55.00 


$20.00 


$15.00 


$0.00 


10/05/01 


Sale 
Sale 


Book 
Book 


$18.00 




$73.00 


$38.00 


$15.00 


$0.00 


,11/05/01 
«1/05/01 


Final F 


Jesuits 


$38.00 


$10.00 
$25.00 


^$63.00 

^$63.00 


^$38.00 
$38.00 


$15.00 
$15.00 


$0.00 
$0.00 



1173 



1171 



FIG 11 J 



1172 



wo 03/014987 PCT/EP02/09483 

19/41 



Closing 
theSTE 
dialog box 
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Waiting for Scalable Template Editor Command 



^1201 



1228 



Handling 
"Should Not 
Occur* 
condition 



Defecting Scalable Template Editor Command 

i — 



Retrieving command parameter. STE_name 



1^1203 



Initialisbig local variables: STE.min=1, STE_maxB255 




Setting variables STE_min, STE^max, copying ST description 
In a WB, filling clipboard with Illustrative range 



1209 



Detennining new unique name in STE_name 

Allocating memory for ST description 
Creating and initialising new record In STT 
Initializing WB with default EP and EF 
Filling Clipboard with Illustrative range 



Loading the "Editor Space" sheet, write-protecting it» preventing meta-element now insertion or deletion, 
Selecting the top left cell of the range of cells Illustrating the scalable template 
Setting STE.format & STE_profile as the format's and profile's names of the currently selected element or meta-element 



1210 



Displaying in the Scalable Template Editor Dialog Box the local variables STE_min, STE.max. STE_name, STE Jbmnat, 
STE_prDfile and displaying finom clipboard the range of cells illustrating the last updated scalable template definition 

^ \Ji\2\2 
WaWng for user action 
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(detecting user action 



Save 
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YES-^ 



Warning & 
prompting 
the user 



PURSUE 



Updating STT table 
with local variables, 
saving WB 




Allocating memory for ST 
description, Creating & 
InifiaUsing new record In 
STT. Saving WB 
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Warning 
the user 



1221 



i 



Updating 
STE_max 
variable 



Yl223 



Done 
Close 
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Format 
update 



1215 



Updating WB . 
clipboard from WB 
and STEJbmiat 
variable 



_l Profile 
3 1 update 

A t 
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Updating WB, 
clipboard from 

WB and 
STE^profile 

variable 



1 



Add 



Inserting row and selecting cell in It, 
Introducing a new mete-element In WB, 
Assigning default values to STEj)rofiIe & 
STE.format, updating clipboard fix>m WB. 



Delete 



Deleting row. Removing 
meta-element from the 
WB. updating clipboard 
fiTwn WB, selecting 
element row 
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New Ins^nce : \ TemplateJ>{anffe 
Element ftfs nf^ 



New lnstgicelS"vgide{4" NO 



New Instance tooTiightt- NO 



Overlay 



Horizontal Insert 



Horizontal Insert by Range 



Vertical Insert 




"YEsnrvEsni yes i 



[Vertical Insert b5> Range [ | YES | | YES | 



1300 



Fig. 13B a 
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Waiting for Scalable Template Instandator Command 



1401 



Detecting Scalable Template Instandator Command 



Retrieving command paramete r ST_name and initialising local variables 



Building woridng variables and woridng ranges of cells 



1^1 403 



Checking new instance size 



-1^1405 



Identifying new instance Impact on existing instances and data 
for each mode of Instandation 



"^1406 



Closing the STI 
Dialog box 



Displaying the Scalable Template instandator Dialog Box 
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Waiting for user action 



1408 



1^1429 
Cancel / Close — 



Detecting user action 



1^1409 



Create- 



Deleting from STIT all 
records corresponding 
to STI cormpted by 
the new STI 



Up 



Increment ing 
STI element 
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Creating a new record 1 J~1415 
In STIT tor the new V-^ 
STI 



Down 
▼ 



selection 



Deaement ing 
STI_eIement 
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V 



Updating 
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mode 



Updating 
STI_mode 
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U u L 



Hortzontal 
Insert 



I: 
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Vertical 
Insert 

ri419 1 



Inserting STl_height 
rows at cument cell 
position 



Inserting STLvwdth ^^^^^^^^ Selecting STl.range 



columns at cun-ent cell 
position 



Horizontal 

Insert 
by Range 



Vertica! 
- Insert 
by Range 
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and insert by range 
STI_height rows at 
current cell position 
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Selecting STl_range 
and insert by range 
STI_width columns at 
cun^nt cell position 



setting first pair 
(format, profile) as 
currant pair, 
STIJndexas 
STLelement 



copying-pasting by value the 
pfcfile description, by attribute 
the format description on the 
current cell 
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Waiting for Scalable Template Instance Insertion Manager Command 



A: 



1501 



Detecting Scalable Template Instance Insertion Manager Command 



^^1502 



Initelising worldng 
-i^ variables and 
1504j^ I ranges of cells 



-YES- 



1505 




CANCEL 
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Warning and 
prompting the 
user 



1514^ 



-CONTINUE^ 



1508 



1507 



Checking new instance size 



1508 



Initialising worldng 
variables and 
ranges of cells 



Identifying Inserton Impact on 
existing instances and data 



Identifying insertion impact on existing instances and data 
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Following 
conventional 
insertion 
method 



Displaying Scalable Template Insert Manager Dialog Box 



Waiting for user action 



Displaying Scalable Template Insert Manager Dialog Box 
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Waiting for user action 



Detecting user action 



Insert 



mode 



'A 



\ 
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Up 



Updating 
SUM mode 



Updating 
STIM critical 
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Incrementing 
STIM_height 



Decrementing 
STlM^height 



Detecting user action 



Close/Cancel 
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Closing STIM 
Dialog box 



nKxie 



Insert 



Deleting from STIT all records of corrupted STI 
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Updating 
STIM mode 



Deleting from STIT all records of corrupted STI 



Horizontal 
Insert 
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Insert 
by Range 
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Insert 
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Inserting 
STIM_height 
rows 



Selecting 
STIM_range_coLfit 
and insert by range 
STIM_helght rows 



I 
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Insert 
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3TIM mode?: 
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Retrieving element pair 
(fonnal, profile), setting 
STIM indexes 
STlM_helght 

I 
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Insert 
by Range 
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- Insert 
by Range 
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Inserting 




Insert ing 






STIM_height 




STIM_width 






rows 




columns 
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Selecting 
STlM_range and 
Insert by range 
STIM_helght rows 
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Selecting 
STIM^range and 
insert by range 
STIM_width 
columns 



moving 
selected cell 
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-NO- 



copying-pastlng by value the profile 
description, by attribute the fomiat 
description on the cunent cell 



decrementing 
STIM index 
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Restoring in former elements 
of the cunent STI the OUT 
fields and update the STIT 
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Fig. 16B 
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0 f^caiahleTemplalG Instii^ Mnnaysr 



CunenI Instance : None ' 



Insert 



Cancel 



^-[l620 

^{^1621 
"^1622 



Critical 

Instance 

Lost 



Other 
Instance 

Lost 
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Data Lost 



Horizorttal Insert 



NO 



NO 



YES 



I Horizontal Insert by Range| | NO 



NO 



YES 



Verticallnsert 



] I YES I I YES I n?ES 
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J. 
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Fig. 19A 
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Selection 




SelecttofT 


too big 




outside 






body 



I Delete IN fields in selected range [ 



I Del^e IN fields in selected rows 
zf I Delete selected elements 



I Delete selected instance 




1904 



1907 



Fig. 19B 
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Current Instance : None 



[Content Delete 




I NO |[~NOnrYES 



I Horizontal Delete 
I Horizontal Delete by Rar^e 



NO 



NO 



YES 



NO 



y I Vertical Delete" 



YES 



NO 



YES 



YES 



YES 



IVerticai Delete by Range | | YES | | YES | ["YES 
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Waiting for Scalabl e Template Refresh Manager Command 





2101 



Detecting Scalable Template Refresh Manager Command 



Retrieving command parameters STRM_name, STRMJype. STRM old 
and Initialising local vartables STRM_ref, STRM^new.STRM^widtti 



2105 



Warning the user ^NO 




12102 



2103 



■YESi 



Initialising woildng ranges of cells STRMJNJoJN and clipboard 
setting first record of STT as sfRM_STT_rec 



^2106 



Setting STDT pointed by STRM_STr_rec as STRM^STDT, 1st STRM_STDT pair as STRMj)air, 
STRM_offset to 0 and ST^name, STRM_top from fields of STRM_STT_rec 



^2107 



Setting next pair of 
STRM_.STDTas STRM_pair, 
incrementing STRM__ofiSset 



T 

NO 
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Setting following 
record of STT as 
STRM STT rec 



YES 
▼ 



Warning the user for 
refresh completion 




YES 



2114 



Setting 1st record of STIT 
as STRM_STIT_rec 



Setting next record of 
STIT as STRM_STITjrec 



Selecting top left cell of instance and moving selection down by STRM_offset 
rows and initialising STRM_body from ElemenW field of STRM_STIT_rec 



Settin g STRMJndex=1 




YES 



Setting 
STRMJndex = 
STRM_body 




At rank STRMJght, copy-pasting 
STRM_new on selection by content 



YES- 



STRM^lndex = 0?>^NO| 
2134 



Moving selection 
down by one row, left 
by(STRM widtti -1) 

"^2135 
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The updated object i$ not referenced by any 


OK -~ 










2213]^ 


















All the existing instances that abtde b^the updated 
dbject have been refreshed 


OK - 
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2202 
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Fig. 23A 




Fig. 23B 



2350]- 
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2348}- 




^ iiecl the Mode for 
the Paste operation: 



J® I Paste as a range of cells ] | VES 4JI-ii0jT 
-O I Paste as elements "] | NO 



-O I Paste as an Instance | [ 
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Watting for Scalable Template Instance Copy Manager Command 



2401 



Detecting Scalal)le Template Instance Copy Command 



1^2402 




2404^J>^ Initialising local variables 

STCopyM_mode, STCopyMjoffeet, STCopyM_name, STCopyM_body, STCopyM_element 




Setting global variables : 
Copy_mode = ELEME^JT 
Copy_name = STCopyM_nanie 
Copy_off5set = STCopyMjoffeet 
Copy_body = STCopyMJbody 
Copy_element = 
STCopyM_elemenl 



Setting global variables : 
Copy^mode = INSTANCE 
Copy_name = STCopyM_name 

Copyjoffeet = Critical 
Copy_body = STCopyM_body 
Copy.element = 0 



Reshaping selection to elements 



2411 



T 



Setting global variables : 
Copy_mode = RANGE 
Copy_name = 
Copy_offset = 0 
Copy_body = 0 
Copy_element = 0 



Reshaping selection to instance, 
Adding a new record In STIT with 
CLIPBOARD as Address field 



2413 



Copying selection to clipboard 



NO 
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Fig. 24A 
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Waitin g for Scalable Template Instance Cut Manager Command 



Detecting Scalalile Template Instance Cut Manager Command 
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—I INL 
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Disabling ELEMENT and 
INSTANCE modes 



2427 



3x( 



Enabling ELEMENT and 
-Tco-^ INSTANCE modes 



2425 



Initialising local variables STCutM.mode. STCutM_offset. STCutM_name. STCutM^body, 
STCutM_elemenL Identifying potential impact on existing scalable template instances 
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I 



Displaying Scalable Template Instance Cut Manager Dialog Box 




Setting global variables : 
Copy^mode = ELEMENT 
Copy_name = STCutM_name 
Copy_offeet = STCutMloffset 
Copy_body = STCutM_body 
Copy_element STCutM_element 



Setting glot>al variat)ies : 
Copy_mode = INSTANCE 
Copy_name = STCutM_name 

Copy^offeet = CritiMi 
Copy_body « STCutM^body 
Copy_element = 0 



Reshaping selection to elements 



T 



Setting global variables : 
Copy_mode - RANGE 
Copy^name = 
Copy.offeet = 0 
Copy_body = 0 
Copy_element = 0 
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Copying selection to clipboard 



Reshaping selection to instance 
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2442 



2435 



SetUng within selection all the "IN" 
fields with a void content 



Cuting selection to clipboard 



Removing from STIT any 
record of corrupted STI 



Removing from STIT any record 
with Address field = CLIPBOARD 
Housekeeping on references 
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Cuting selection to clipboard 



Changing Address field of cun-ent 
Instance record to CLIPBOARD 
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2441 



2444 
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Fig. 24B 
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Waiting fty Scalable Template Instance Paste Manager Command 



Detecting Scalable T emplate Instance Paste Command 



Determining destination range of cells de8t.fange and initialising local variables 
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Pasting clipboard onto 
dest_range 
conventlonaliy 



^NO 




Creating a record in STIT 



Pasting clipboard onto dest_range A 
conventionally by content 
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I Enabling INSTANCE mode 



Identifying potential impact on existing scalable template instances 



E 



2467Xr 



Closing 
STPasteM 
Dialog box 



2476 



Displaying Scalable Template Instance Paste Manager Dialog Box ^ 


i 




Waiting for user action 




i 






-Close / Cancel Detecting user action — mode-> 

1 \r 


Updating 
STPasteM^mode 





r RANGE- 



2470}^ 

;;§tPasteM mode=T 



Removing any corrupted STI from STIT 



J 
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2469 
-INSTANCE 



Reshaping dest^range to element 



Pasting clipboard onto 
des^range conventionally 
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2473 



Updating STIT recoixJ 



2474 



Reshaping dest_range to instance 



Fig. 24C 
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Waiting for Scalable Template Export Manager Command 



Detedir^ Scalable Template Export Manager Command 



Displaytng Scalable Tem plate Export Manager Dialog Box 

* 



Waiting for user action 



Detecting user action 



|2502 
[2503 
[2504 
-^2505 




New Ills 

T 



2507 



Retrieving file from user 



Cancel/ 
Close - 



2506 



2511 



Waming user 



Kin YES 

m J~2510 memory, initialising local 

T . n variables: 



Loading file data in 
^mory, initialising lo 

variables: 
STEMJndex1=1 



Closing STEM dialog box 



Loading default file data in 
memory, initialising local 
variables: 
STEMJndex1=1 
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Refreshing Scalable Template Export Manager Dialog Box 



_ZII^— - 



Setting the curre nt STMT record with index equal to STEMJndexl as STEM STMT rec 



2517 



2527 



Incrementing 
STEM Indexl 



STEM Jndex2 = 1 



-YES- 



Settlng the cunrent STEIT record with Index equal ^^2518 
to STEMJndex2 as STEM^STEIT^rec 





Saving STEIT table and 
associated descriptions to file 



2524 



Prompting user for 
replacement 



YES- 



Creatlng a new record In 
STEIT fix)m STEM_STMT_rec 
with associated description 



Replacing in STEIT 
STEM„STElT_rec by 
STEM_STMT_recwlth 
associated description 



YES TO ALL Lnq. 
I ^^25 26 



Setting 
STEM_rBplace_aII=YES 



1 
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Waiting for Scalable Template Import Manager Command 



Detecting Scalable Template Import Manager Command 



2532 



Displaying Scalable Template Import Manager Dialog Box 



-1^2533 




Warning user 



Loading file data in memory, initialising local variables: 
STIMJndexl, STIM_STEIT_size, STIM_STMT_size. 



2541 



2542]^ 



Refreshing Scalable Template I mport Manager Dialog Box 



SetUng the current STEIT record wHh Index equal to STIMJndexl as STiM_STElT_rec | 



3 



STIM index2 = 1 



1^2543 



2554 



'3m 



Incrementing STIMJndexl 



Setting the current STMT record with Index equal 

to STIMJndex2 as STIM_STMT„rec "^2544 • 




YES 



Incrementing 
STIM index2 



Creating a new record In 
STMT and Ef=T/EPT/STT from 
STIM_STEIT_recwith 
associated description 



Replacing In STMT and EFT/ 
EPT/Srr STIM^STMT.rec by 
STIM_STEiT_rec with 
associated description 



Setting 
STIM_replace_an=YES 



Fig. 25B 
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Fig. 26B 
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Fig. 26C 
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Spreadhseet Export-Import File Header 



STEIT-Ifke Table 



Descriptor Area 
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Fig. 27A 



Fig. 27B 
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Import File : 


Re Name 


Instance Name : 


Current Instance Nan^ 


Template Name : 


Currenlt Template Nairn 


Processing: |||| 





Fig. 27C 



Field # 



Jj740 



Field Content 



Exported Scalable Template Instance Table 
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Fig. 27D 



Spreadhseet Instance Export-Import Re Header 
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STIEIT-IIke Table 
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Descriptor Area (containing ESTIT tables) 
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Waifing for Scalable Template Instance Export Manager Command 
Detecting Scaiat)lQ Temptete Instance Expwt Manager Command 




Warning user ^NO- 



Loading file data in memory, 
InHialising local variables. 



I Ctosing STEM dialog tx»c 



Loading default file data In 
memory, InlQallsing local 
vartaMes. 



Refreshing Scalable Template Instance Export Manager Dialog Box 

T 



Setting top record of STIEIT as current one: STIEM_STIEIT_rec 

r2818 



-1^2817 



YES 




2822 



Prompting 
YESH user for 
replacement 



-NO- 



Creating a new STIEIT record: SnEM_STiEIT_rec 



2835J 
— YES 

Updating STIEM_STIEIT_rec^ I 



Saving STEIT table 

and associated 
ESTIT table to file 



Initialising local variables: STIEM_coi=1; 
STlEM_export_col=1; SnEM_profile_cell 



Copy^pastlng by value STIEM_STI_ceH on STIEM_ESTI_ce!l 

Shifting STIEM_ESTLcell rights by 1 column 
Incrementing STIEM export col 



Shifting STIEM_STI__cell rights by i column 
ShHHng STIEM jDrofile_ceIl rights by 1 column 
Incrementing STIEM col 



Shifting STIEM^ESTLcell left by STIEM_export_col column 
Riling STIEM_ESTLcell with STIEM.export col 
Shifting STIEM ESTLcell rinhts bv 1 column 



£ 



Shifting STIEM.STLcell left by STIEM col-1 column 
Shifting STIEM^STLcell dovwi by 1 row 
Shifting STIEM ESTI. cell down by 1 row 



Next STDT record becoming STIEM_STDT_rBC U — i 
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Incrementing STIEM row 
Refreshing STIEM Dialog Box 




< 




YES 



NO 
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Waiting for Scalable Template Instance Import Manager Command 
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Initialising 
STIIM__EST!_cell. 
STUM row max 



Initialising local variables: STIIM_col=1 ; 
STIIM_export„ool=1; STIIM_profile_celI; 
STI IM_export_col_max 
Sliiffing STIIM_ESTl_cell rights by 1 column 



Copy-pasting by value STUM EST! cell on STUM STI cell ^ 
Shifting STllM_ESTLcetl rights by 1 column 
Incrementing STIIM_export ool 
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Shifting STIIM^STljceU rights by 1 coiumn 
Shifting STIIM_profile_cell rights by 1 column 
Incrementing STUM col 




YES 
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Waiting for Scalable Template Instance Sort AppDcation Manager Command 



i 



Detecting ScalabiB Template Instance Sort Application Manager Command 
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Disabling ELEMENT and 

INSTANCE modes, 
initialising STISM_mode 
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Initialising STISM_mode 



InitlaOsing STISM^name. Identifying potential impact on existing scalable template instances 
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Displaying Scalable Template instance Sort Manager Dialog Box 
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Waiting for user action 
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-Close / Cancel - 



Detecting user action — mode-^ 
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Reshaping selection to; elements 
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Reshaping selection to all the 
elements within the Instance 
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Removing from STfT any 
record of oomjpted STI 



Retrieving from user conventional Sort application options 
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Invoking the conventional Sort application for cunent selection 
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Fig. 29A 
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Fig. 298 
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